.NET C#使用NPOI将Excel中的数据批量导入到MySQL

.NET C#使用NPOI将Excel中的数据批量导入到MySQL

猿掌柜
2024-01-10 / 0 评论 / 38 阅读 / 正在检测是否收录...

1336199-20200909010339493-1716062953.gif

一、引入NPOI NuGet:

通过NuGet管理解决方案安装:

搜索:NPOI进行安装:

二、ASP.NET Core使用EF Core连接MySQL执行简单的CRUD操作:

因为该篇文章会涉及到MySQL数据库的操作,所以前提我们需要有一点的CRUD的基础。这里就不做详细的讲解了

三、使用NPOI获取Excel数据注意点:

1、关于Excel的版本问题

做过Excel相关工作的人应该都清楚Office Excel的格式有两种:

a、一种是.XLS是03版的Office Excel,无法打开高版本的。

b、一种是.XLSX是07版(或者07以上的)的Office Excel,可以打开低版本的。

所以我们在使用NPOI导入数据时不同格式获取Excel工作簿对象也有所不同,如下代码所示:

//Workbook对象代表一个工作簿,首先定义一个Excel工作薄
IWorkbook workbook;
 
//XSSFWorkbook 适用XLSX格式,HSSFWorkbook 适用XLS格式
#region 判断Excel版本
switch (fileType)
{
    //.XLSX是07版(或者07以上的)的Office Excel
    case ".xlsx":
        workbook = new XSSFWorkbook(stream);
        break;
    //.XLS是03版的Office Excel
    case ".xls":
        workbook = new HSSFWorkbook(stream);
        break;
    default:
        throw new Exception("Excel文档格式有误");
}
#endregion

2、NPOI获取Excel单元格中不同类型的数据:

#region NPOI获取Excel单元格中不同类型的数据
//获取指定的单元格信息
var cell = row.GetCell(j);
switch (cell.CellType)
{
    //首先在NPOI中数字和日期都属于Numeric类型
    //通过NPOI中自带的DateUtil.IsCellDateFormatted判断是否为时间日期类型
    case CellType.Numeric when DateUtil.IsCellDateFormatted(cell):
        dataRow[j] = cell.DateCellValue;
        break;
    case CellType.Numeric:
        //其他数字类型
        dataRow[j] = cell.NumericCellValue;
        break;
    //空数据类型
    case CellType.Blank:
        dataRow[j] = "";
        break;
    //公式类型
    case CellType.Formula:
    {
        HSSFFormulaEvaluator eva = new HSSFFormulaEvaluator(workbook);
        dataRow[j] = eva.Evaluate(cell).StringValue;
        break;
    }
    //布尔类型
    case CellType.Boolean:
        dataRow[j] = row.GetCell(j).BooleanCellValue;
        break;
    //错误
    case CellType.Error:
        dataRow[j] = HSSFErrorConstants.GetText(row.GetCell(j).ErrorCellValue);
        break;
    //其他类型都按字符串类型来处理(未知类型CellType.Unknown,字符串类型CellType.String)
    default:
        dataRow[j] = cell.StringCellValue;
        break;
}
#endregion
四、通用的NPOI Excel导入数据帮助类(NpoiExcelImportHelper):
/**
 * Description:Npoi数据导入帮助类
 * Description:2024年1月10日
 */
using System;
using System.Data;
using System.IO;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;

namespace YY_Utility
{
    public class NpoiExcelImportHelper
    {
        private static NpoiExcelImportHelper _excelImportHelper;

        public static NpoiExcelImportHelper _
        {
            get => _excelImportHelper ?? (_excelImportHelper = new NpoiExcelImportHelper());
            set => _excelImportHelper = value;
        }

        /// <summary>
        /// 读取excel表格中的数据,将Excel文件流转化为dataTable数据源  
        /// 默认第一行为标题 
        /// </summary>
        /// <param name="stream">excel文档文件流</param>
        /// <param name="fileType">文档格式</param>
        /// <param name="isSuccess">是否转化成功</param>
        /// <param name="resultMsg">转换结果消息</param>
        /// <returns></returns>
        public DataTable ExcelToDataTable(Stream stream, string fileType, out bool isSuccess, out string resultMsg)
        {
            isSuccess = false;
            resultMsg = "Excel文件流成功转化为DataTable数据源";
            var excelToDataTable = new DataTable();

            try
            {
                //Workbook对象代表一个工作簿,首先定义一个Excel工作薄
                IWorkbook workbook;

                //XSSFWorkbook 适用XLSX格式,HSSFWorkbook 适用XLS格式
                #region 判断Excel版本
                switch (fileType)
                {
                    //.XLSX是07版(或者07以上的)的Office Excel
                    case ".xlsx":
                        workbook = new XSSFWorkbook(stream);
                        break;
                    //.XLS是03版的Office Excel
                    case ".xls":
                        workbook = new HSSFWorkbook(stream);
                        break;
                    default:
                        throw new Exception("Excel文档格式有误");
                }
                #endregion

                var sheet = workbook.GetSheetAt(0);
                var rows = sheet.GetRowEnumerator();

                var headerRow = sheet.GetRow(0);
                int cellCount = headerRow.LastCellNum;//最后一行列数(即为总列数)

                //获取第一行标题列数据源,转换为dataTable数据源的表格标题名称
                for (var j = 0; j < cellCount; j++)
                {
                    var cell = headerRow.GetCell(j);
                    excelToDataTable.Columns.Add(cell.ToString());
                }
              //补充一个获取图片
              var pictures = workbook.GetAllPictures();
              string polor_img=string.Empty;//路径
              foreach (XSSFPictureData pic in pictures) 
              {
                  
                  string ext = pic.SuggestFileExtension();
                  Image png = Image.FromStream(new MemoryStream(pic.Data));
                  polor_img = savepath+"\\"+c_id+"."+ ext;
                  png.Save(polor_img);
                  polor_img = $"{DateTime.Now:yyyyMMdd}/{c_id}.{ext}";
              }

                //获取Excel表格中除标题以为的所有数据源,转化为dataTable中的表格数据源
                for (var i = (sheet.FirstRowNum + 1); i <= sheet.LastRowNum; i++)
                {
                    var dataRow = excelToDataTable.NewRow();

                    var row = sheet.GetRow(i);

                    if (row == null) continue; //没有数据的行默认是null 

                    for (int j = row.FirstCellNum; j < cellCount; j++)
                    {
                        if (row.GetCell(j) != null)//单元格内容非空验证
                        {
                            #region NPOI获取Excel单元格中不同类型的数据
                            //获取指定的单元格信息
                            var cell = row.GetCell(j);
                            switch (cell.CellType)
                            {
                                //首先在NPOI中数字和日期都属于Numeric类型
                                //通过NPOI中自带的DateUtil.IsCellDateFormatted判断是否为时间日期类型
                                case CellType.Numeric when DateUtil.IsCellDateFormatted(cell):
                                    dataRow[j] = cell.DateCellValue;
                                    break;
                                case CellType.Numeric:
                                    //其他数字类型
                                    dataRow[j] = cell.NumericCellValue;
                                    break;
                                //空数据类型
                                case CellType.Blank:
                                    dataRow[j] = "";
                                    break;
                                //公式类型
                                case CellType.Formula:
                                {
                                    HSSFFormulaEvaluator eva = new HSSFFormulaEvaluator(workbook);
                                    dataRow[j] = eva.Evaluate(cell).StringValue;
                                    break;
                                }
                                //布尔类型
                                case CellType.Boolean:
                                    dataRow[j] = row.GetCell(j).BooleanCellValue;
                                    break;
                                //错误
                                case CellType.Error:
                                    dataRow[j] = HSSFErrorConstants.GetText(row.GetCell(j).ErrorCellValue);
                                    break;
                                //其他类型都按字符串类型来处理(未知类型CellType.Unknown,字符串类型CellType.String)
                                default:
                                    dataRow[j] = cell.StringCellValue;
                                    break;
                            }
                            #endregion
                        }
                    }
                    excelToDataTable.Rows.Add(dataRow);
                }

                isSuccess = true;
            }
            catch (Exception e)
            {
                resultMsg = e.Message;
            }

            return excelToDataTable;
        }
    }
}

OK~结束

1

评论 (0)

取消