应用ExcelPackage导出Excel
前阵子工作需要,要实现从数据库中导出数据到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的更多相关文章
- ASP.NET Core 导入导出Excel xlsx 文件
ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...
- C# NPOI导出Excel和EPPlus导出Excel比较
系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http: ...
- asp.net下简单的Epplus导出excel
引用的命名空间 using System.IO; using OfficeOpenXml; /// <summary> /// 导出excel /// </summary> / ...
- 导出Excel之Epplus使用教程1(基本介绍)
1.前言 目前Epplus的介绍中文资料很少,我也一直在摸索中使用它,以下是我在使用过程中得到的经验,写出来供大家参考.本系列共4章: 导出Excel之Epplus使用教程1(基本介绍) 导出Exce ...
- Mvc 拼接Html 导出 Excel(服务器不用安装呦!支持2007以上版本)
新公司,新接触,老方法,更实用. 之前接触过Webform,winfrom 的导出Excel方法 ,优点:省事.缺点:服务器必须安装Office 这几天做项目 和 大牛学习了一下 新的方法,自己加以总 ...
- 导出Excel之Epplus使用教程3(图表设置)
导出Excel之Epplus使用教程1(基本介绍) 导出Excel之Epplus使用教程2(样式设置) 导出Excel之Epplus使用教程3(图表设置) 导出Excel之Epplus使用教程4(其他 ...
- ASP.NET导出Excel(利用NPOI和EPPlus库,无需安装Office)
网上提供了很多Asp.net中操作Excel的方法,其中大部分是调用微软的Office组件,下面提供三个无须安装Office即可从Asp.net输出Excel的方法. 1 简单方法 //下面代码输出的 ...
- Epplus:导出Excel
看到其它大神的Epplus导出Excel,结合写出符合自己需求的将导出数据到Excel,给其它人参考一下,也可以学习http://www.cnblogs.com/caofangsheng/p/6149 ...
- C# EPPlus导出EXCEL,并生成Chart表
一 在negut添加EPPlus.dll库文件. 之前有写过直接只用Microsoft.Office.Interop.Excel 导出EXCEL,并生成Chart表,非常耗时,所以找了个EPPlus ...
随机推荐
- 协同编辑多人word一个小技巧文件
协同编辑多人word窍门 近期在工作中编写标书时因为不同内容分给了各个部门去制作.可是在汇总后遇到再次改动的问题.对方把改动后的部分文档发给我粘贴到标书中后,所有的格式所有都乱了.又一次整理格式.标题 ...
- 【原创】编写多线程Python爬虫来过滤八戒网上的发布任务
目标: 以特定语言技术为关键字,爬取八戒网中网站设计开发栏目下发布的任务相关信息 需求: 用户通过设置自己感兴趣的关键字或正则表达式,来过滤信息. 我自己选择的是通过特定语言技术作为关键字,php.j ...
- T-SQL基础(7) - 透视,逆透视和分组集
透视转换: use tempdb;if object_id('dbo.Orders', 'U') is not null drop table dbo.Orders;create table dbo. ...
- bootstarp modal自己主动调整宽度的JS代码
$('#ajaxPage').modal('show').css({ width: 'auto', 'margin-left': function () { return -($(this).widt ...
- 单选框和下拉框的jquery操作
单选框 <input type="radio" name="rdSendType" value="email" checked=&qu ...
- 使用HTML5 Canvas做些什么
百分比圆环进度条 // ----------------------------------------------------------- 柱状排行榜统计图 // ------------ ...
- 【android】优秀的UI资源站点集合
1.http://ionicons.com/ 这个站点的图标能满足大部分人的需求.里面包括了经常使用的android风格的图标 ios7风格的图标 以及一些社会化分享图标,总共500个左右.githu ...
- AND信号灯和信号灯集-----同步和互斥解决面向对象(两)
AND信号 互斥的上述处理,它是针对仅在进程之间共享的一个关键资源方面.在一些应用.这是一个过程,需要在为了自己的使命后,获得两个或多个其他共享资源运行. 个进程A和B.他们都要求訪问共享数据D和E. ...
- 【转】HLSL基础
原文地址http://blog.csdn.net/chpdirect1984/article/details/1911622 目录 前言 1.HLSL入门 1.1什么是着色器 1.2什么是HLSL 1 ...
- windows API与C#的数据类型对应关系表
API与C#的数据类型对应关系表 API数据类型 类型描述 C#类型 API数据类型 类型描述 C#类型 WORD 16位无符号整数 ushort CHAR 字符 char LONG 32位无符号整数 ...