使用EPPLUS操作EXcel

时间 2014-11-06 19:28:01  姜糖水
主题 Excel

1 下载Epplus最新版: http://epplus.codeplex.com/

2 在项目中添加引用 EEPULS.dll(测试环境Win7+V2010旗舰)

3  添加using引用

using OfficeOpenXml;

using OfficeOpenXml.Drawing;

using OfficeOpenXml.Drawing.Chart;

using OfficeOpenXml.Style;

4 read Excel文件

private void button2_Click(object sender, EventArgs e)
    {
      string pfilePath = "";
      OpenFileDialog ofd = new OpenFileDialog();
      ofd.Filter = "*.xls|*.xlsx";
      if (ofd.ShowDialog() == System.Windows.Forms.DialogResult.OK)
      {
        pfilePath = ofd.FileName;
      }
      if (string.IsNullOrEmpty(pfilePath))
      {
        MessageBox.Show("没有选中文件");
        return;
      }

      FileInfo existingFile = new FileInfo(pfilePath);
      try
      {
        ExcelPackage package = new ExcelPackage(existingFile);
        int vSheetCount = package.Workbook.Worksheets.Count; //获取总Sheet页

        ExcelWorksheet worksheet = package.Workbook.Worksheets[1];//选定 指定页

        int maxColumnNum = worksheet.Dimension.End.Column;//最大列
        int minColumnNum = worksheet.Dimension.Start.Column;//最小列

        int maxRowNum = worksheet.Dimension.End.Row;//最小行
        int minRowNum = worksheet.Dimension.Start.Row;//最大行

        DataTable vTable = new DataTable();
        DataColumn vC;
        for (int j = 1; j <= maxColumnNum; j++)
        {
          vC = new DataColumn("A_" + j, typeof(string));
          vTable.Columns.Add(vC);
        }
        if (maxRowNum > 200)
        {
          maxRowNum = 200;
        }
        for (int n = 1; n <= maxRowNum; n++)
        {
          DataRow vRow = vTable.NewRow();
          for (int m = 1; m <= maxColumnNum; m++)
          {
            vRow[m - 1] = worksheet.Cells[n, m].Value;
          }
          vTable.Rows.Add(vRow);
        }
        this.dataGridView1.DataSource = vTable;
      }
      catch (Exception vErr)
      {
        MessageBox.Show(vErr.Message);
      }
    }

5 write Excel文件

private void button1_Click(object sender, EventArgs e)
        {

     OfficeOpenXml.ExcelPackage ep = new OfficeOpenXml.ExcelPackage();
     OfficeOpenXml.ExcelWorkbook wb = ep.Workbook;
     OfficeOpenXml.ExcelWorksheet ws = wb.Worksheets.Add("我的工作表");
     //配置文件属性
     wb.Properties.Category = "类别";
     wb.Properties.Author = "作者";
     wb.Properties.Comments = "备注";
     wb.Properties.Company = "公司";
     wb.Properties.Keywords = "关键字";
     wb.Properties.Manager = "管理者";
     wb.Properties.Status = "内容状态";
     wb.Properties.Subject = "主题";
     wb.Properties.Title = "标题";
     wb.Properties.LastModifiedBy = "最后一次保存者";
     //写数据
     ws.Cells[1, 1].Value = "Hello";

     ws.Column(1).Width=40;//修改列宽
     ws.Cells["B1"].Value = "World";
     ws.Cells[3, 3, 3, 5].Merge = true;
     ws.Cells[3, 3].Value = "Cells[3, 3, 3, 5]合并";
     ws.Cells["A4:D5"].Merge = true;
     ws.Cells["A4"].Value = "Cells[\"A4:D5\"]合并";

     SaveFileDialog sfd = new SaveFileDialog();
     sfd.Filter = "*.xls|*.xlsx";
     if (sfd.ShowDialog() == System.Windows.Forms.DialogResult.OK)
     {
         FileInfo file = new FileInfo(sfd.FileName);
         ep.File = file;
         ep.Save();
         MessageBox.Show("保存成功");
     }
     else
     {
         MessageBox.Show("取消保存");
     }
        }

上述代码大部分来源网络,只进行过小改动,下面是原文和资料地址:

http://blog.csdn.net/jimmy2248/article/details/8363697

http://blog.csdn.net/zhoufoxcn/article/details/14112473

http://www.cnblogs.com/liudeyun/p/3535740.html

http://blog.163.com/china__xuhua/blog/static/19972316920136335721285/

使用EPPLUS操作EXcel的更多相关文章

  1. C#使用第三方组件Epplus操作Excel表

    Epplus操作Excel基础详解 1.什么是Epplus Epplus是一个使用Open Office XML文件格式,能读写Excel2007/2010文件的开源组件,在导出Excel的时候不需要 ...

  2. ASP.NET Core使用EPPlus操作Excel

    1.前言 本篇文章通过ASP.NET Core的EPPlus包去操作Excel(导入导出),其使用原理与NPOI类似,导出Excel的时候不需要电脑上安装office,非常好用 2.使用 新建一个AS ...

  3. 使用LinqToExcel和EPPlus操作excel

    1.使用LinqToExcel LinqToExcel是一个.net framework平台下开源项目,它主要实现了LINQ的语法查询Excel电子表格.类型之前的LINQToXXX如果你是LINQ语 ...

  4. c#用EPPLUS操作excel

    参考: http://www.cnblogs.com/rumeng/p/3785748.html http://www.cnblogs.com/libla/p/5824296.html#3818995 ...

  5. [Solution] NPOI操作Excel

    NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目.使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 ...

  6. .net 操作excel

    .net 操作excel的常用组件:EPPlus,NPOI 1.NPOI,即POI的.NET版本(POI是一套用Java写成的库,能够帮助开发者在没有安装微软Office的情况下读写Office文件, ...

  7. 【代码沉淀】 - EPPlus - 操作xlsx表格文件

    EPPlus - Create advanced Excel spreadsheets on the server.web: http://epplus.codeplex.com/nuget: Ins ...

  8. C# 操作 Excel(.xls和.xlsx)文件

    C#创建Excel(.xls和.xlsx)文件的三种方法 .NET 使用NPOI导入导出标准Excel C# 使用NPOI 实现Excel的简单导入导出 NET使用NPOI组件将数据导出Excel-通 ...

  9. [Asp.net] C# 操作Excel的几种方式 优缺点比较

    在项目中我们常常需要将数据库中的数据导出成Excel文件 有一次工作中我的目的就是读取Excel到内存中,整理成指定格式 整理后再导出到Excel. 因为我要处理的每个Excel表格文件很大.一个表格 ...

随机推荐

  1. ContentProvider官方教程(3)ContentResolver查询、遍历 示例

    Retrieving Data from the Provider This section describes how to retrieve data from a provider, using ...

  2. ord函数-php

    摘录自http://php.net/manual/zh/function.ord.php (PHP 4, PHP 5, PHP 7) ord — 返回字符的 ASCII 码值 说明 int ord ( ...

  3. js对cookie的操作,包括增,取,删

    在其他人都开会到时间里,我偷偷摸哦的试了一下cookie,唉,从来没有用过cookie,慢慢的知识忘光了,还好这次偷偷摸摸的做出来了,虚,大家都别出声啊 <!DOCTYPE html> & ...

  4. jquery之wrap(),wrap(),unwrap()方法详解

    [注]wrap():为每个匹配元素外面添加指定的HTML结构, wrapAll(): 为所有匹配元素(作为一个整体)外面添加一个指定的HTML结构 原文地址:http://www.365mini.co ...

  5. Spring整合Tiles

    1.假设Spring相关的包和配置已经导入成功(后续有时间补上,本项目用的是3.2.0版本). 2.导入Tiles相关的jar包. tiles-api-2.2.2.jar tiles-core-2.2 ...

  6. GoAccess日志分析工具使用文档

    ----Sevck 2016/3/4 17:24:13 #1软件说明: GoAccess是一款开源.实时,运行在命令行终端下的web日志分析工具.该工具提供快速.多样的HTTP状态统计,可以令管理员不 ...

  7. xml读写文件实例

    在某个通讯中需要向服务器发送请求xml,格式例子如下: <?xml version="1.0" encoding="UTF-8"?> <ROO ...

  8. IBM Lotus Domino V8.5 服务器管理入门手册

    转自 http://freemanluo.blog.51cto.com/636588/336128

  9. 如何写好CSS?(OOCSS\DRY\SMACSS)

    我现在面对的CSS基本上就是一个三头六臂的怪物,一点不夸张,因为真的是三头六臂,同一个样式在同一个element上作用了好几遍,而同一个样式又分散在4,5个class上,优先级有很多层.可以看得出这个 ...

  10. GCC编译器和GDB调试器常用选项

    http://blog.csdn.net/u014328976/article/details/46745349 GCC编译器 gcc hello.c -o hello                 ...