C#通过NPOI操作Excel的实例代码

C#操作Excel的方法有很多种,常见的有微软官方的OLE Automation,Apache的POI等。这里介绍的是POI翻译成C#的NPOI。

POI是Apache的通过Java操作Office的一个API,可以对Excel,Word,PPT等进行操作,十分的强大。然后就被翻译成C#版本的NPOI了,和log4j与log4net很相似。

好像在NPOI的.net4.0版本之前是不支持office2007及以上的XML格式的,但是最新的版本已经支持了。只需要下载并引用下面五个程序集就能使用了。

这里提供一个操作Excel的类,类中提供了4个方法,两个导出,两个导入。可以通过DataSet导出拥有多个Sheet的Excel文件,也可以通过DataTable导出拥有一个Sheet的Excel。导入也是一样,通过指定Sheet索引,导出DataTable,或者直接导出所有Sheet返回一个DataSet。

public class ExcelHelper
  {
    /// <summary>
    /// 根据Excel和Sheet返回DataTable
    /// </summary>
    /// <param name="filePath">Excel文件地址</param>
    /// <param name="sheetIndex">Sheet索引</param>
    /// <returns>DataTable</returns>
    public static DataTable GetDataTable(string filePath, int sheetIndex)
    {
      return GetDataSet(filePath, sheetIndex).Tables[0];
    }

    /// <summary>
    /// 根据Excel返回DataSet
    /// </summary>
    /// <param name="filePath">Excel文件地址</param>
    /// <param name="sheetIndex">Sheet索引,可选,默认返回所有Sheet</param>
    /// <returns>DataSet</returns>
    public static DataSet GetDataSet(string filePath, int? sheetIndex = null)
    {
      DataSet ds = new DataSet();
      IWorkbook fileWorkbook;
      using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read))
      {
        if (filePath.Last() == 's')
        {
          try
          {
            fileWorkbook = new HSSFWorkbook(fs);
          }
          catch (Exception ex)
          {
            throw ex;
          }
        }
        else
        {
          try
          {
            fileWorkbook = new XSSFWorkbook(fs);
          }
          catch
          {
            fileWorkbook = new HSSFWorkbook(fs);
          }
        }
      }

      for (int i = 0; i < fileWorkbook.NumberOfSheets; i++)
      {
        if (sheetIndex != null && sheetIndex != i)
          continue;
        DataTable dt = new DataTable();
        ISheet sheet = fileWorkbook.GetSheetAt(i);

        //表头
        IRow header = sheet.GetRow(sheet.FirstRowNum);
        List<int> columns = new List<int>();
        for (int j = 0; j < header.LastCellNum; j++)
        {
          object obj = GetValueTypeForXLS(header.GetCell(j) as HSSFCell);
          if (obj == null || obj.ToString() == string.Empty)
          {
            dt.Columns.Add(new DataColumn("Columns" + j.ToString()));
          }
          else
            dt.Columns.Add(new DataColumn(obj.ToString()));
          columns.Add(j);
        }
        //数据
        IEnumerator rows = sheet.GetEnumerator();
        while (rows.MoveNext())
        {
          int j = sheet.FirstRowNum + 1;
          DataRow dr = dt.NewRow();
          bool hasValue = false;
          foreach (int K in columns)
          {
            dr[K] = GetValueTypeForXLS(sheet.GetRow(K).GetCell(K) as HSSFCell);
            if (dr[K] != null && dr[K].ToString() != string.Empty)
            {
              hasValue = true;
            }
          }
          if (hasValue)
          {
            dt.Rows.Add(dr);
          }
          j++;
        }
        ds.Tables.Add(dt);
      }

      return ds;
    }

    /// <summary>
    /// 根据DataTable导出Excel
    /// </summary>
    /// <param name="dt">DataTable</param>
    /// <param name="file">保存地址</param>
    public static void GetExcelByDataTable(DataTable dt, string file)
    {
      DataSet ds = new DataSet();
      ds.Tables.Add(dt);
      GetExcelByDataSet(ds, file);
    }

    /// <summary>
    /// 根据DataSet导出Excel
    /// </summary>
    /// <param name="ds">DataSet</param>
    /// <param name="file">保存地址</param>
    public static void GetExcelByDataSet(DataSet ds, string file)
    {
      IWorkbook fileWorkbook = new HSSFWorkbook();
      int index = 0;
      foreach (DataTable dt in ds.Tables)
      {
        index++;
        ISheet sheet = fileWorkbook.CreateSheet("Sheet" + index);

        //表头
        IRow row = sheet.CreateRow(0);
        for (int i = 0; i < dt.Columns.Count; i++)
        {
          ICell cell = row.CreateCell(i);
          cell.SetCellValue(dt.Columns[i].ColumnName);
        }

        //数据
        for (int i = 0; i < dt.Rows.Count; i++)
        {
          IRow row1 = sheet.CreateRow(i + 1);
          for (int j = 0; j < dt.Columns.Count; j++)
          {
            ICell cell = row1.CreateCell(j);
            cell.SetCellValue(dt.Rows[i][j].ToString());
          }
        }
      }

      //转为字节数组
      MemoryStream stream = new MemoryStream();
      fileWorkbook.Write(stream);
      var buf = stream.ToArray();

      //保存为Excel文件
      using (FileStream fs = new FileStream(file, FileMode.Create, FileAccess.Write))
      {
        fs.Write(buf, 0, buf.Length);
        fs.Flush();
      }
    }

    /// <summary>
    /// 根据单元格将内容返回为对应类型的数据
    /// </summary>
    /// <param name="cell">单元格</param>
    /// <returns>数据</returns>
    private static object GetValueTypeForXLS(HSSFCell cell)
    {
      if (cell == null)
        return null;
      switch (cell.CellType)
      {
        case CellType.Blank: //BLANK:
          return null;
        case CellType.Boolean: //BOOLEAN:
          return cell.BooleanCellValue;
        case CellType.Numeric: //NUMERIC:
          return cell.NumericCellValue;
        case CellType.String: //STRING:
          return cell.StringCellValue;
        case CellType.Error: //ERROR:
          return cell.ErrorCellValue;
        case CellType.Formula: //FORMULA:
        default:
          return "=" + cell.CellFormula;
      }
    }
  }

这里面可以有一些有意思的操作,比如版本兼容问题。这里通过多态很好的实现了兼容,但是如果是2007版本的xlsm被修改为xsl的后缀怎么办呢,或者2003版本的被修改为xlsm后缀怎么办呢。2003版本改为xlsm还是可以将其视为xls来处理的,但是2007改为xls就不行了。这时候可以强行修改文件的后缀名再打开。

但是上面的代码没有实现这个功能,两个原因:一、这样做不是很安全。二、这时候需要修改系统中其它地方此文件的文件名,放在类中实现不是很方便。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • npoi2.0将datatable对象转换为excel2007示例

    NPOI 2.0将DataTable对象转换为Excel 2007文件提供下载 复制代码 代码如下: using NPOI.SS.UserModel;using NPOI.XSSF.UserModel;using System.IO;        private Stream RenderDataTableToExcel(DataTable SourceTable)        {            XSSFWorkbook workbook = null;            Mem

  • 使用Npoi操作excel的解决办法

    Npoi 简介-------------------------------------------------------------------------------- 1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet:行:Row:单元格Cell. 2.Npoi 下载地址:http://npoi.codeplex.com/releases/view/38113 4.忘了告诉大家npoi是做什么的了,npoi 能够读写几乎所有的Office 97

  • 详解免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)

    很多的软件项目几乎都包含着对文档的操作,前面已经介绍过两款操作文档的组件,现在介绍一款文档操作的组件NPOI. NPOI可以生成没有安装在您的服务器上的Microsoft Office套件的Excel报表,并且在后台调用Microsoft Excel ActiveX更有效率;从Office文档中提取文本,以帮助您实现全文索引功能(大多数时候,此功能用于创建搜索引擎): 从Office文档提取图像: 生成包含公式的Excel工作表.  一.NPOI组件概述: NPOI是完全免费使用: 涵盖Exce

  • c# 应用NPOI获取Excel中的图片,保存至本地的算法

    要求:读取excel中的图片,保存到指定路径 思路:  利用NPOI中 GetAllPictures()方法获取图片信息 步骤: 1.新建一个Windows窗体应用程序 2.桌面新建一个excel,贴入两张图片 如下图: 3.在Form中拖入一个button 4.点击button,在点击事件方法中写入,要读取图片的方法:ExcelToImage 点击事件方法如下: private string exclePath = @"C:\users\lenovo\Desktop\testPic.xls&q

  • 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

    今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Excel中格式的设置,以及单元格的合并等等.下面就介绍下,使用NPOI类库操作Excel的方法. 1.首先我们先在内存中生成一个Excel文件,代码如下:   HSSFWorkbook book = new HSSFWorkbook();        ISheet sheet = book.CreateSheet("Sheet1"); 2.然后在新创建的sheet里面,创建我们的行和列,代码如下

  • C#基于NPOI生成具有精确列宽行高的Excel文件的方法

    本文实例讲述了C#基于NPOI生成具有精确列宽行高的Excel文件的方法,是非常具有实用价值的技巧分享给大家供大家参考.具体方法如下:. 一.前言 NPOI是操作Excel的神器,导出导入快如闪电, 但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更难搞懂了. //附带SetColumnWidth的用法和注释 IWorkbook hssfworkbook = new HSSFWorkbook(); ISh

  • C#使用NPOI导入Excel的方法详解

    本文实例讲述了C#使用NPOI导入Excel的方法.分享给大家供大家参考,具体如下: NPOI是由国人开发的一个进行excel操作的第三方库.百度百科介绍如下:NPOI 本文主要介绍如何使用NPOI将Excel数据读取. 首先引入程序集: using System.IO; using System.Reflection; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.Web; 然后定位到文件位置: string

  • C#使用NPOI上传excel

    写本文章的目的是为了记录工作中遇到的问题,方便以后遇到可以迅速解决问题 我使用的NPOI版本是2.2.1.0版本 需要用到的命名空间 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; 首先需要读取excel文件中的内容转为表格 string path为excel表格文件的在本地的地址 Stream fs为上传文件的流可以根据Request.Files[0].InputStream  获得

  • asp.net使用npoi读取excel模板并导出下载详解

    为什么要使用NPOI导出Excel? 一.解决传统操作Excel遇到的问题: 如果是.NET,需要在服务器端装Office,且及时更新它,以防漏洞,还需要设定权限允许.NET访问COM+,如果在导出过程中出问题可能导致服务器宕机.Excel会把只包含数字的列进行类型转换,本来是文本型的,Excel会将其转成数值型的,比如编号000123会变成123.导出时,如果字段内容以"-"或"="开头,Excel会把它当成公式进行,会报错.Excel会根据Excel文件前8行分

  • Asp.Net使用Npoi导入导出Excel的方法

    asp.net针对Excel文件的导入与导出是非常常见的功能之一.本文实例讲述了Asp.Net使用Npoi导入导出Excel的方法.分享给大家供大家参考之用.具体方法如下: 在使用Npoi导出Excel的时候,服务器可以不装任何office组件,一般在导出时用到Npoi导出Excel文件,所导Excel也符合规范,打开时也不会有任何文件损坏之类的提示.但是在做导入时还是使用OleDb的方式,这种方式的导入在服务器端似乎还是需要装office组件的. 一.Npoi导出/下载Excel 具体功能代码

随机推荐