使用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. git版本控制器

    Git 是一个开源的分布式版本控制系统 Google用于android 源代码的管理就是Git,  它支持离线工作, 本地提交可以稍后提交到服务器上. 众多的开源项目都使用 Git  作为版本控制系统 ...

  2. sql 集合运算

    UNION 并运算 UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列.列也必须拥有相似的数据类型.同时,每条 SE ...

  3. Eclipse / android studio 添加第三方jar包 步骤

    eclipse 将第三方包放到libs文件夹后并没有引用. 基本步骤分为3步,具体介绍如下: 打开自己的Eclipse,在自己的Android工程上名上右键->Build Path ->C ...

  4. 昂贵的聘礼 Dijkstra法

    poj 1062 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 39437   Accepted: 11432 Descri ...

  5. Mysql ERROR 1064 (42000)

    创建了一个表: +-------------+--------------+------+-----+---------+----------------+ | Field | Type | Null ...

  6. 针对各种浏览器css不兼容的写法

    /*针对谷歌浏览器内核支持的CSS样式*/@media screen and (-webkit-min-device-pixel-ratio:0) { 样式 } /*针对IE6特制识别的CSS样式*/ ...

  7. VBA中自定义类和事件的(伪)注册

    想了解一下VBA中自定义类和事件,以及注册事件处理程序的方法. 折腾了大半天,觉得这样的方式实在称不上“注册”,所以加一个“伪”字.纯粹是瞎试,原理也还没有摸透.先留着,有时间再接着摸. 做以下尝试: ...

  8. [SAP ABAP开发技术总结]文本文件、Excel文件上传下传

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. Scrum Meeting---Seven(2015-11-2)

    今日已完成任务和明日要做的任务 姓名 今日已完成任务 今日时间 明日计划完成任务 估计用时 董元财 完成了服务器实现 5h 服务器与客户端连接测试 4h 胡亚坤 客户端与服务器端的通信 2h 客户端与 ...

  10. js输出26个字母两种方法(js fromCharCode的使用)

    方法一 var character = new Array("A","B","C","D","E", ...