使用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. raid0,raid1,raid10,raid5,raid50,raid6,raid60的功能总结简述

    1,raid0的特性:采用剥离,数据将在几个磁盘上进行分割.数据被分成很多数据块,每一数据块会被写入不同的磁盘.从而, 每一磁盘的工作负荷都得到了降低,这有助于加速数据传输.RAID-0可让磁盘更好地 ...

  2. .Net六大验证及使用方法

    C#包含有六种验证方式,分别为: 一.非空验证  RequiredFieldValidator. 二.对比验证 CompareValidator. 三.范围验证 RangeValidator. 四.正 ...

  3. Download file using libcurl in C/C++

    http://stackoverflow.com/questions/1636333/download-file-using-libcurl-in-c-c #include <stdio.h&g ...

  4. Android——例子:屏幕切换

    效果图如下:                          Xml文件代码: <?xml version="1.0" encoding="utf-8" ...

  5. 对称加密DES和TripleDES

    一.  对称加密 对称加密,是一种比较传统的加密方式,其加密运算.解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码(称为对称密码).因此,通信双方都必 ...

  6. 个人博客作业_week2

    1. 是否需要有代码规范   1.这些规范都是官僚制度下产生的浪费大家的编程时间.影响人们开发效率,浪费时间的东西. 我不同意这个论点.      有句俗语’无规矩不成方圆‘,这亘古传承的至理同样适用 ...

  7. 2013/7/17 HNU_训练赛5

    sgu 542 Gena vs Petya sgu 543 Cafe 题意:有N组人需要被分配到某些固定了人数的桌子上,其中ai表示第i组有多少个人,安排作为需要符合如下安排:某一组的人员不能够单独在 ...

  8. 16位的MD5加密和32位MD5加密的区别

    16位的MD5加密和32位MD5加密的区别 MD5加密后所得到的通常是32位的编码,而在不少地方会用到16位的编码它们有什么区别呢?16位加密就是从32位MD5散列中把中间16位提取出来!其实破解16 ...

  9. 超实用压力测试工具-ab工具

    在学习ab工具之前,我们需了解几个关于压力测试的概念 吞吐率(Requests per second)概念:服务器并发处理能力的量化描述,单位是reqs/s,指的是某个并发用户数下单位时间内处理的请求 ...

  10. Redis基础知识之————使用技巧(持续更新中.....)

    一.key 设计技巧 把表名转换为key前缀 如, tag: 第2段放置用于区分区key的字段--对应mysql中的主键的列名,如userid 第3段放置主键值,如2,3,4...., a , b , ...