前阵子工作需要,要实现从数据库中导出数据到Excel。老套路 先去百度上查阅资料,发现了以下几种方法:

1:将DataGrid控件中的数据导出Excel

2:将dataview导出excel

3:从网页上用html绘制Excel 表格  等。。

总体上感觉比较繁琐 比如用dataview导出excel时, Excel表格的格式需要在程序中设置,不利于后期的修改维护。而ExcelPackage的优势就是解放了在程序中设置格式的弊端,总体原理为:在相应路径下放置一个Excel模板,执行导出操作时按照模板样式在指定行插入数据,构建出一个模板样式的新Excel。

excelpackage的官网:http://excelpackage.codeplex.com/ ,里面有所需的.dll文件和demo程序。

接下来是我应用Excelpackage导出Excel的小程序,就当抛砖引玉了~      代码如下:

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;
using System.IO;
using OfficeOpenXml; namespace twins
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {         }         protected void btnExcel_Click(object sender, EventArgs e)
        {
            // DataTable dt = getData().Tables[0];
            FileInfo newFile = new FileInfo(Server.MapPath("~/new.xls")); //生成的Excel,放在根目录下了
            string path = Server.MapPath("~/template.xls");   //模板Excel,放在根目录下
            FileInfo template = new FileInfo(path);
            if (!template.Exists)
               throw new Exception("Template file does not exist!");
            using (ExcelPackage xlPackage = new ExcelPackage(newFile, template))
            {
                // uncomment this line if you want the XML written out to the outputDir
                //xlPackage.DebugMode = true;                  // get handle to the existing worksheet
                ExcelWorksheet worksheet = xlPackage.Workbook.Worksheets["student"];  //Excel的sheet1位置
                if (worksheet != null)
                {
                    ExcelCell cell;
                    const int startRow = ;           //开始插入数据的数据行,自行设置
                    int row = startRow;                     using (SqlDataReader sqlReader = getReader())
                    {
                        // get the data and fill rows 5 onwards
                        while (sqlReader.Read())
                        {
                            int col = ;
                            // we have our total formula on row 7, so push them down so we can insert more data
                            if (row > startRow) worksheet.InsertRow(row);                             // our query has the columns in the right order, so simply
                            // iterate through the columns
                            for (int i = ; i < sqlReader.FieldCount; i++)
                            {
                                // use the email address as a hyperlink for column 1
                                if (sqlReader.GetName(i) == "EmailAddress")
                                {
                                    // insert the email address as a hyperlink for the name
                                    string hyperlink = "mailto:" + sqlReader.GetValue(i).ToString();
                                    worksheet.Cell(row, ).Hyperlink = new Uri(hyperlink, UriKind.Absolute);
                                }
                                else
                                {
                                    // do not bother filling cell with blank data (also useful if we have a formula in a cell)
                                    if (sqlReader.GetValue(i) != null)
                                        worksheet.Cell(row, col).Value = sqlReader.GetValue(i).ToString();
                                    col++;
                                }
                            }
                            row++;
                        }                         sqlReader.Close();                         // delete the two spare rows we have in the template
                        worksheet.DeleteRow(row, true);
                        worksheet.DeleteRow(row, true);
                        row--;
                    }
                    //用于设置excel表的格式
                    for (int iCol = ; iCol <= ; iCol++)               
                    {
                        cell = worksheet.Cell(startRow, iCol);
                        for (int iRow = startRow; iRow <= row; iRow++)
                        {
                            worksheet.Cell(iRow, iCol).StyleID = cell.StyleID;
                        }
                    }
                
                }
                         // save the new spreadsheet
                try
                {
                    xlPackage.Save();  //保存生成的Excel
                }
                catch(Exception e3){
                    
                }
                
            }
        }         protected SqlDataReader getReader()
        {
            const string connStr = "server=.;database =oz;Integrated Security =true";
            SqlConnection mySqlConnection = new SqlConnection(connStr);//新建连接对象  
            string sqlStr = " select name,sex,tel,email,job from student";//SQL语句  
            mySqlConnection.Open();//打开连接  
            SqlCommand common = new SqlCommand(sqlStr, mySqlConnection);
            SqlDataReader sdr = common.ExecuteReader();
            return sdr;
           
        }
    }
}

在根目录下放置一个template.xls文件--用于模板。我的模板如下图所示:

运行程序,会把数据库student表中数据插入到excel中,我本机的student表如下图所示:

之后在根目录下会看到生成一个新Excel文件-new.xls. 迫不及待的打开,看到如下图 所示:

成功!!!

值得注意的是:

1:执行程序之后,template.xls是不会变的(它只是一个模板),改变的只有新生成的new.xls

2:new.xls 1,2行中静态的标题和标头的样式和模板是一致的,而动态的数据样式可以在模板excel中设置。在我此程序设置的方法为:在模板的第三行,右击鼠标->设置单元格格式->对齐居中,字体华文行楷。 设置后生成的excel中就能出现上图所示的效果,是不是很方便呐~

3: 经测试,2步骤的设置貌似只能在Excel2007中生效,也就是说如果在excel2003中设置字体和居中都是无效的!我也没有办法,同学们可以自己试一试 如果可以的话告诉我一声啊。

应用ExcelPackage导出Excel的更多相关文章

  1. ASP.NET Core 导入导出Excel xlsx 文件

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...

  2. C# NPOI导出Excel和EPPlus导出Excel比较

    系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http: ...

  3. asp.net下简单的Epplus导出excel

    引用的命名空间 using System.IO; using OfficeOpenXml; /// <summary> /// 导出excel /// </summary> / ...

  4. 导出Excel之Epplus使用教程1(基本介绍)

    1.前言 目前Epplus的介绍中文资料很少,我也一直在摸索中使用它,以下是我在使用过程中得到的经验,写出来供大家参考.本系列共4章: 导出Excel之Epplus使用教程1(基本介绍) 导出Exce ...

  5. Mvc 拼接Html 导出 Excel(服务器不用安装呦!支持2007以上版本)

    新公司,新接触,老方法,更实用. 之前接触过Webform,winfrom 的导出Excel方法 ,优点:省事.缺点:服务器必须安装Office 这几天做项目 和 大牛学习了一下 新的方法,自己加以总 ...

  6. 导出Excel之Epplus使用教程3(图表设置)

    导出Excel之Epplus使用教程1(基本介绍) 导出Excel之Epplus使用教程2(样式设置) 导出Excel之Epplus使用教程3(图表设置) 导出Excel之Epplus使用教程4(其他 ...

  7. ASP.NET导出Excel(利用NPOI和EPPlus库,无需安装Office)

    网上提供了很多Asp.net中操作Excel的方法,其中大部分是调用微软的Office组件,下面提供三个无须安装Office即可从Asp.net输出Excel的方法. 1 简单方法 //下面代码输出的 ...

  8. Epplus:导出Excel

    看到其它大神的Epplus导出Excel,结合写出符合自己需求的将导出数据到Excel,给其它人参考一下,也可以学习http://www.cnblogs.com/caofangsheng/p/6149 ...

  9. C# EPPlus导出EXCEL,并生成Chart表

    一  在negut添加EPPlus.dll库文件. 之前有写过直接只用Microsoft.Office.Interop.Excel 导出EXCEL,并生成Chart表,非常耗时,所以找了个EPPlus ...

随机推荐

  1. cocos2d-x笔记(十一)Lua发展飞机战争-5- 让飞机动

    然后在飞机上已被添加到游戏,下一步是让它动起来.主要是为了应对触摸事件. 在C++通过重写ccTouchBegan().ccTouchMoved().ccTouchEnded()三个函数来响应触摸事件 ...

  2. [状压dp] hdu 4064 Carcassonne

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4064 Carcassonne Time Limit: 3000/1000 MS (Java/Othe ...

  3. 191. Number of 1 Bits Leetcode Python

    Write a function that takes an unsigned integer and returns the number of '1' bits it has (also know ...

  4. C和指针 (pointers on C)——第十四章:预处理器

    第十四章 预处理器 我跳过了先进的指针主题的章节. 太多的技巧,太学科不适合今天的我.但我真的读,读懂.假设谁读了私下能够交流一下.有的小技巧还是非常有意思. 预处理器这一章的内容.大家肯定都用过.什 ...

  5. hibernate它 10.many2many单向

    在前文hibernate之5.many2one单向提到多对多关系,表结构设计是基于中间表来实现, 以下以用户与角色(多对多)为例,在Hibernate是怎样操作的 表结构设计: 类图: CRUD; S ...

  6. robot framework 使用三:他们主动浏览器的兼容性

    robot framework 浏览器兼容性测试 上图中黄色圈的地方默认什么都不写,是firefox浏览器.写上ie就是ie浏览器了 firefox最新版本号即可,ie须要设置: 1. IE选项设置的 ...

  7. linux内核数据包转发流程(三)网卡帧接收分析

    [版权声明:转载请保留出处:blog.csdn.net/gentleliu.邮箱:shallnew*163.com] 每一个cpu都有队列来处理接收到的帧,都有其数据结构来处理入口和出口流量,因此,不 ...

  8. Webuploader 大文件分片上传

    百度Webuploader 大文件分片上传(.net接收)   前阵子要做个大文件上传的功能,找来找去发现Webuploader还不错,关于她的介绍我就不再赘述. 动手前,在园子里找到了一篇不错的分片 ...

  9. 在高德地图应用api,和api展出的标记小的应用程序

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  10. 【ASP.NET】关于iframe的两个技巧

    原文:[ASP.NET]关于iframe的两个技巧 最近在给朋友写个网站,虽然不大,但是也碰到了一些问题.这篇就为解决ASP.NET中关于IFRAME的两个很现实的问题提供解决方法.PS:呵呵,又做了 ...