C#使用NOPI库实现导入Excel文档

使用NOPI导入Excel文档

NOPI版本:2.3.0,依赖于NPOI的SharpZipLib版本:0.86,经测试适用于.net4.0+

记录遇到的几个问题

1.NOPI中的IWorkbook接口:xls使用HSSFWorkbook类实现,xlsx使用XSSFWorkbook类实现

2.日期转换,判断row.GetCell(j).CellType == NPOI.SS.UserModel.CellType.Numeric && HSSFDateUtil.IsCellDateFormatted(row.GetCell(j)

不能直接使用row.GetCell(j).DateCellValue,这玩意会直接抛出异常来~

1. 将文件流转换为DataTable

  /// <summary>
  /// 根据Excel格式读取Excel
  /// </summary>
  /// <param name="stream">文件流</param>
  /// <param name="type">Excel格式枚举类型,xls/xlsx</param>
  /// <param name="sheetName">表名,默认取第一张</param>
  /// <returns>DataTable</returns>
  private static DataTable ImportExcel(Stream stream, ExcelExtType type, string sheetName)
  {
    DataTable dt = new DataTable();
    IWorkbook workbook;
    try
    {
      //xls使用HSSFWorkbook类实现,xlsx使用XSSFWorkbook类实现
      switch (type)
      {
        case ExcelExtType.xlsx:
          workbook = new XSSFWorkbook(stream);
          break;
        default:
          workbook = new HSSFWorkbook(stream);
          break;
      }
      ISheet sheet = null;
      //获取工作表 默认取第一张
      if (string.IsNullOrWhiteSpace(sheetName))
        sheet = workbook.GetSheetAt(0);
      else
        sheet = workbook.GetSheet(sheetName);

      if (sheet == null)
        return null;
      IEnumerator rows = sheet.GetRowEnumerator();
      #region 获取表头
      IRow headerRow = sheet.GetRow(0);
      int cellCount = headerRow.LastCellNum;
      for (int j = 0; j < cellCount; j++)
      {
        ICell cell = headerRow.GetCell(j);
        if (cell != null)
        {
          dt.Columns.Add(cell.ToString());
        }
        else
        {
          dt.Columns.Add("");
        }
      }
      #endregion
      #region 获取内容
      for (int i = (sheet.FirstRowNum + 1); i <= sheet.LastRowNum; i++)
      {
        IRow row = sheet.GetRow(i);
        DataRow dataRow = dt.NewRow();

        for (int j = row.FirstCellNum; j < cellCount; j++)
        {
          if (row.GetCell(j) != null)
          {
            //判断单元格是否为日期格式
            if (row.GetCell(j).CellType == NPOI.SS.UserModel.CellType.Numeric && HSSFDateUtil.IsCellDateFormatted(row.GetCell(j)))
            {
              if (row.GetCell(j).DateCellValue.Year >=1970)
              {
                dataRow[j] = row.GetCell(j).DateCellValue.ToString();
              }
              else
              {
                dataRow[j] = row.GetCell(j).ToString();

              }
            }
            else
            {
              dataRow[j] = row.GetCell(j).ToString();
            }
          }
        }
        dt.Rows.Add(dataRow);
      }
      #endregion

    }
    catch (Exception ex)
    {
      dt=null;
    }
    finally
    {
      //if (stream != null)
      //{
      //  stream.Close();
      //  stream.Dispose();
      //}
    }
    return dt;
  }

2. 文件上载导入

  /// <summary>
  /// 上传Excel导入
  /// </summary>
  /// <param name="file">上载文件对象</param>
  /// <param name="errorMsg">错误信息</param>
  /// <param name="sheetName">表名,默认取第一张</param>
  /// <returns></returns>
  public static DataTable Import(System.Web.HttpPostedFileBase file, ref string errorMsg, string sheetName = "")
  {
    if (file == null || file.InputStream == null || file.InputStream.Length == 0)
    {
      errorMsg = "请选择要导入的Excel文件";
      return null;
    }
    var excelType = GetExcelFileType(file.FileName);
    if (excelType == null)
    {
      errorMsg = "请选择正确的Excel文件";
      return null;
    }
    using (var stream = new MemoryStream())
    {
      file.InputStream.Position = 0;
      file.InputStream.CopyTo(stream);
      var dt = ImportExcel(stream, excelType.Value, sheetName);
      if (dt == null)
        errorMsg = "导入失败,请选择正确的Excel文件";
      return dt;
    }
  }

3. 本地路径读取导入

  /// <summary>
  /// 根据文件路径导入Excel
  /// </summary>
  /// <param name="filePath"></param>
  /// <param name="errorMsg">错误信息</param>
  /// <param name="sheetName">表名,默认取第一张</param>
  /// <returns>可能为null的DataTable</returns>
  public static DataTable Import(string filePath, ref string errorMsg, string sheetName = "")
  {
    var excelType = GetExcelFileType(filePath);
    if (GetExcelFileType(filePath) == null)
    {
      errorMsg = "请选择正确的Excel文件";
      return null;
    }
    if (!File.Exists(filePath))
    {
      errorMsg = "没有找到要导入的Excel文件";
      return null;
    }
    DataTable dt;
    using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
    {
      dt = ImportExcel(stream, excelType.Value, sheetName);
    }
    if (dt == null)
      errorMsg = "导入失败,请选择正确的Excel文件";
    return dt;
  }

4.完整demo

附赠一个winform导入Excel的Demo。

https://github.com/yimogit/NopiExcelDemo

(0)

相关推荐

  • c#利用Excel直接读取数据到DataGridView

    在winform里拖入一个datagridview控件,跟一个openfiledialog控件 复制代码 代码如下: using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using Microsoft.Office.Core;using Excel=Mi

  • C#使用oledb操作excel文件的方法

    本文实例讲述了C#使用oledb操作excel文件的方法.分享给大家供大家参考.具体分析如下: 不管什么编程语言都会提供操作Excel文件的方式,C#操作Excel主要有以下几种方式: 1.Excel 说明:利用Office 的Excel组件来操作excel文件 优点:能够完全操作Excel文件,生成丰富文件内容 缺点:需要电脑安装Excel,会启动Excel进程这在web上很不方便 2.OpenXML 说明:一个操作字处理文档的组件包括Excel 优点:能够操作操作Excel2007版本文件

  • C#导入导出EXCEL文件的代码实例

    复制代码 代码如下: using System;using System.Data;using System.Data.OleDb; namespace ZFSoft.Joint{    public class ExcelIO    {        private int _ReturnStatus;        private string _ReturnMessage; /// <summary>        /// 执行返回状态        /// </summary&g

  • ASP.NET(C#)读取Excel的文件内容

    .xls格式       Office2003及以下版本 .xlsx格式 Office2007 及以上版本 .csv格式       以逗号分隔的字符串文本(可以将上述两种文件类型另存为此格式) 读取前两种格式和读取后一种格式会用两种不同的方法. 下面看程序:页面前台: 复制代码 代码如下: <div>       <%-- 文件上传控件  用于将要读取的文件上传 并通过此控件获取文件的信息--%>      <asp:FileUpload ID="fileSele

  • c#将Excel数据导入到数据库的实现代码

    假如Excel中的数据如下: 数据库建表如下: 其中Id为自增字段: 代码: 复制代码 代码如下: using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.UI;using System.Web.UI.WebControls;using System.Data;using System.Data.OleDb;using System.Configuratio

  • C#将html table 导出成excel实例

    复制代码 代码如下: public void ProcessRequest (HttpContext context) { string elxStr = "<table><tbody><tr><td>1</td><td>11</td></tr><tr><td>2</td><td>22</td></tr></tbody>

  • C#实现将DataTable内容输出到Excel表格的方法

    本文实例讲述了C#实现将DataTable内容输出到Excel表格的方法.分享给大家供大家参考.具体如下: 1.关于本文 本文描述了一个函数(SaveToExcel),该函数可以将DataTable数据内的数据输出到Excel表格中 2.相关说明 1)本文中使用这个函数将一个DataTable中的内容输出到路径名为addr的目录下: 复制代码 代码如下: public void SaveToExcel(string addr, System.Data.DataTable dt) 2)这个函数需要

  • C#数据导入/导出Excel文件及winForm导出Execl总结

    一.asp.net中导出Execl的方法: 在asp.net中导出Execl有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出流写给浏览器.在Response输出时,\t分隔的数据,导出execl时,等价于分列,\n等价于换行. 1.将整个html全部输出execl 此法将html中所有的内容,如按钮,表格,图片等全部输出到Execl中. 复制代码 代码如下: Response.Clear(); Response.Buffer= t

  • C# WinForm导出Excel方法介绍

    .NET开发人员首选的方法,通过COM组件调用Office软件本身来实现文件的创建和读写,但是数据量较大的时候异常缓慢:如下代码所示已经做了优化,将一个二维对象数组赋值到一个单元格区域中(下面的代码中只能用于导出列数不多于26列的数据导出): Office PIA 复制代码 代码如下: public static void ExportToExcel(DataSet dataSet, string outputPath){    Excel.ApplicationClass excel = ne

  • C#如何将DataTable导出到Excel解决方案

    最近,由于公司项目中需要将系统内用户操作的所有日志进行转存备份,考虑到以后可能还需要还原,所以最后决定将日志数据备份到Excel中. 下面是我项目当中Excel.cs这个类的全部代码,通过这个类可以很容易地将DataTable中的数据导入到Excel方法中. 首先,必须要下载NPOI.dll这个程序集, 类代码如下: 复制代码 代码如下: using System; using NPOI.HSSF; using NPOI.HPSF; using NPOI.HSSF.UserModel; usin

随机推荐