全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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就不行了。这时候可以强行修改文件的后缀名再打开。

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

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


# npoi操作excel  # c#  # excel  # npoi  # C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例  # C#将Excel中的数据转换成DataSet  # C#使用NPOI导入Excel的方法详解  # C#基于NPOI生成具有精确列宽行高的Excel文件的方法  # c# 根据NPOI 读取一个excel 文件的多个Sheet  # c# 应用NPOI获取Excel中的图片  # 保存至本地的算法  # C#使用NPOI上传excel  # C# 基于NPOI操作Excel  # C#实现NPOI的Excel导出详解  # C#使用NPOI读取excel转为DataSet  # 可以通过  # 翻译成  # 单元格  # 类中  # 的是  # 这时候  # 很好  # 放在  # 就能  # 多个  # 不是很  # 将其  # 微软  # 这样做  # 不支持  # 只需要  # 可选  # 提供一个  # 不行了  # 这里面 


相关文章: 如何用美橙互联一键搭建多站合一网站?  已有域名如何免费搭建网站?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何在Windows环境下新建FTP站点并设置权限?  如何零成本快速生成个人自助网站?  如何在阿里云购买域名并搭建网站?  如何用西部建站助手快速创建专业网站?  如何基于PHP生成高效IDC网络公司建站源码?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  如何通过多用户协作模板快速搭建高效企业网站?  北京企业网站设计制作公司,北京铁路集团官方网站?  C#如何序列化对象为XML XmlSerializer用法  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  c++怎么用jemalloc c++替换默认内存分配器【性能】  详解jQuery中基本的动画方法  非常酷的网站设计制作软件,酷培ai教育官方网站?  如何配置WinSCP新建站点的密钥验证步骤?  如何选择域名并搭建高效网站?  如何批量查询域名的建站时间记录?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  高防服务器租用如何选择配置与防御等级?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  北京网站制作网页,网站升级改版需要多久?  如何通过VPS建站无需域名直接访问?  网站制作软件有哪些,制图软件有哪些?  如何在万网自助建站平台快速创建网站?  如何在IIS7中新建站点?详细步骤解析  C++时间戳转换成日期时间的步骤和示例代码  建站之星后台密码遗忘或太弱?如何重置与强化?  宝塔新建站点报错如何解决?  行程制作网站有哪些,第三方机票电子行程单怎么开?  浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  如何在局域网内绑定自建网站域名?  深圳网站制作平台,深圳市做网站好的公司有哪些?  制作网站外包平台,自动化接单网站有哪些?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何注册花生壳免费域名并搭建个人网站?  网站代码制作软件有哪些,如何生成自己网站的代码?  建站之星免费模板:自助建站系统与智能响应式一键生成  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  如何快速生成高效建站系统源代码?  如何在Windows虚拟主机上快速搭建网站?  如何获取上海专业网站定制建站电话?  *服务器网站为何频现安全漏洞?  如何在IIS7上新建站点并设置安全权限?  建站主机与服务器功能差异如何区分? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。