NPOI.HSSF 导入excel数据(记录)

2024-04-25 02:48

本文主要是介绍NPOI.HSSF 导入excel数据(记录),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://download.csdn.net/download/ttbat/15435334  NPOI.HSSF.Dll 下载地址。

在项目引用 NPOI.HSSF.Dll 后 using NPOI.HSSF.UserModel;

PS:excel文件只能读取1997-2003版本的,2007以上的excel版本无法读取。

        /// <summary>/// /// </summary>/// <param name="path">文件地址</param>/// <param name="_syptktService"></param>/// <param name="success">成功数量</param>/// <param name="failure">错误数量</param>/// <returns></returns>
public static string ImprotSXSC(string path, ISYPTKTService _syptktService, out int success, out int failure){string errorMsg = string.Empty;success = failure = 0;try{HSSFWorkbook hssfworkbook;using (FileStream file = new FileStream(path, FileMode.Open, FileAccess.Read)){#region 检查excel数据hssfworkbook = new HSSFWorkbook(file);HSSFSheet sheet = hssfworkbook.GetSheetAt(0);if (sheet == null || sheet.LastRowNum < 0){errorMsg = "excel格式异常,请检查";return errorMsg;}Dictionary<string, int> headCellDic = GetCellDictNum(sheet, 0); //表头键与索引集合errorMsg = CheckExcel(sheet);if (!string.IsNullOrEmpty(errorMsg))return errorMsg;#endregionHSSFRow row = null;HSSFCell cell;string rowMsg;int startRowIndex = 1;for (int i = startRowIndex; i <= sheet.LastRowNum; i++){                        row = sheet.GetRow(i);cell = row.GetCell(headCellDic["A"]);string name = getCellStringValue(row, cell, "A", out rowMsg);var model = _syptktService.GetSxScxts(s => s.NAME.Contains(name)).FirstOrDefault();bool isnew = false;int failure1 = 0;if (model == null){model = new SXSCXTEntiry();isnew = true;}model.NAME = name;cell = row.GetCell(headCellDic["B"]);string X = getCellStringValue(row, cell, "B", out rowMsg);cell = row.GetCell(headCellDic["C"]);string Y = getCellStringValue(row, cell, "C", out rowMsg);float x = CommonMethodNew.FromDFM(X);float y = CommonMethodNew.FromDFM(Y);model.X = X;model.Y = Y;if (X != "" && Y != "" && x >= 3 && y >= 2){model.SHAPE = "POINT ( " + x + " " + y + ")";}if (string.IsNullOrEmpty(name)){failure1++;errorMsg += string.Format("第{0}行水下生产系统名称未录入$", i);}if (string.IsNullOrEmpty(model.SHAPE)){failure1++;errorMsg += string.Format("{0}水下生产系统经纬度数据不正确$", name);                           }if (failure1 > 0){ failure++; continue; }}}}catch (Exception ex){failure++;errorMsg = ex.ToString();}return errorMsg;}/// <summary>/// 获取excel指定行中,列键值(键/索引)集合/// </summary>/// <param name="sheet"></param>/// <param name="rowIndex"></param>/// <returns></returns>public static Dictionary<string, int> GetCellDictNum(HSSFSheet sheet,int rowIndex){Dictionary<string, int> celldict = new Dictionary<string, int>();HSSFRow frow = sheet.GetRow(rowIndex);int colNum = frow.PhysicalNumberOfCells;char A = 'A';int Acode = (int)A;int firA = 0;String sfir = "";String stow = "";for (int i = 0; i < colNum; i++){if (i < 26){celldict.Add(((char)(Acode + i)).ToString(), i);}else if (i >= 26 && i <= (26 * 26)){firA = i / 26;sfir = ((char)(Acode + firA - 1)).ToString();firA = i % 26;stow = ((char)(Acode + firA)).ToString();celldict.Add(sfir + stow, i);}}return celldict;}/// <summary>/// 获取文本格式/// </summary>/// <param name="row"></param>/// <param name="cell"></param>/// <param name="cellKey"></param>/// <param name="errorMsg"></param>/// <returns></returns>public static string getCellStringValue(HSSFRow row, HSSFCell cell, string cellKey, out string errorMsg){errorMsg = string.Empty;string value = null;if (cell == null){return null;}if (cell.CellType == HSSFCell.CELL_TYPE_NUMERIC)value= cell.NumericCellValue.ToString();else if (cell.CellType == HSSFCell.CELL_TYPE_STRING)value= cell.StringCellValue;else{try{value = cell.StringCellValue;}catch (Exception ex){errorMsg = string.Format("文档第" + (row.RowNum + 1) + "行," + cellKey + "列格式不正确");}}if(!string.IsNullOrEmpty(value))value = value.Trim().Replace("\n", "").Replace(" ", "").Replace("\t", "").Replace("\r", ""); ;return value;}

 

这篇关于NPOI.HSSF 导入excel数据(记录)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/933520

相关文章

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Nacos日志与Raft的数据清理指南

《Nacos日志与Raft的数据清理指南》随着运行时间的增长,Nacos的日志文件(logs/)和Raft持久化数据(data/protocol/raft/)可能会占用大量磁盘空间,影响系统稳定性,本... 目录引言1. Nacos 日志文件(logs/ 目录)清理1.1 日志文件的作用1.2 是否可以删除

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

Python实现pdf电子发票信息提取到excel表格

《Python实现pdf电子发票信息提取到excel表格》这篇文章主要为大家详细介绍了如何使用Python实现pdf电子发票信息提取并保存到excel表格,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录应用场景详细代码步骤总结优化应用场景电子发票信息提取系统主要应用于以下场景:企业财务部门:需

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de