DataSet数据导出为Excel文档(每个DataTable为一个Sheet)
Web项目中,很多时候须要实现将查询的数据集导出为Excel文档的功能,很多时候不希望在工程中添加对Office组件相关的DLL的引用,甚至有时候受到Office不同版本的影响,导致在不同的服务器上部署后功能受限,或和其它项目冲突,那么,使用这种简单粗暴的方式,可能会解决部分猿类灵长动物的烦恼忧愁。
/// <summary>
/// DataSet导出到Excel文件(多个Sheet)
/// </summary>
/// <param name="dataSet">DataSet</param>
/// <param name="fileName">文件名称</param>
/// <returns>导出是否成功</returns>
public static bool DataSetToExcel(DataSet dataSet, string fileName)
{
if (dataSet == null) return false;
if (dataSet.Tables.Count < ) return false;
if (dataSet.Tables[] == null) return false;
if (string.IsNullOrWhiteSpace(fileName)) return false;
try
{
ExecDataSetToExcel(dataSet, fileName);
return true;
}
catch (Exception ex)
{
//DO LOG
return false;
}
}
//执行 DataSet 导出
private static void ExecDataSetToExcel(DataSet dataSet, string fileName)
{
HttpResponse httpResponse = HttpContext.Current.Response;
httpResponse.Clear();
httpResponse.Charset = "utf-8";
httpResponse.ContentType = "text/xml";
httpResponse.ContentEncoding = System.Text.Encoding.UTF8;
httpResponse.AppendHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName, Encoding.UTF8) + ".xls"); StringBuilder sb = new StringBuilder();
for (int i = ; i < dataSet.Tables.Count; i++)
{
System.Data.DataTable dt = dataSet.Tables[i];
//新建Sheet
string sheetName = string.IsNullOrWhiteSpace(dt.TableName) ? "Sheet" + (i + ) : dt.TableName;
sb.Append("<Worksheet ss:Name='" + sheetName + "'>");
sb.Append("<Table x:FullColumns='1' x:FullRows='1' ss:DefaultColumnWidth='118'>");
//输出标题行
sb.Append("<Row ss:AutoFitHeight='1'>");
for (int j = ; j < dt.Columns.Count; j++) sb.Append("<Cell ss:StyleID='header'><Data ss:Type='String'>" + dt.Columns[j].ColumnName + "</Data></Cell>");
sb.Append("</Row>");
//输入内容行
for (int k = ; k < dt.Rows.Count; k++)
{
sb.Append("<Row>");
for (int l = ; l < dt.Columns.Count; l++)
{
//Type ct = dt.Columns[l].DataType;
//sb.Append("<Cell ss:StyleID='body'><Data ss:Type='Number'>" + dt.Rows[k][l] + "</Data></Cell>"); //数字类型
sb.Append("<Cell ss:StyleID='body'><Data ss:Type='String'>" + dt.Rows[k][l] + "</Data></Cell>");
}
sb.Append("</Row>");
}
sb.Append("</Table>");
sb.Append("</Worksheet>");
} string excelXmlDoc = CreateExcelXmlDoc(sb.ToString());
httpResponse.Write(excelXmlDoc);
httpResponse.Flush();
httpResponse.End();
}
//创建Excel文档对应的XML字符串
private static string CreateExcelXmlDoc(string worksheetXml)
{
StringBuilder sb = new StringBuilder();
sb.Append("<?xml version='1.0'?><?mso-application progid='Excel.Sheet'?>");
sb.Append("<Workbook xmlns='urn:schemas-microsoft-com:office:spreadsheet' xmlns:o='urn:schemas-microsoft-com:office:office'"
+"xmlns:x='urn:schemas-microsoft-com:office:excel' xmlns:ss='urn:schemas-microsoft-com:office:spreadsheet'"
+"xmlns:html='http://www.w3.org/TR/REC-html40'>");
//文档属性
sb.Append("<DocumentProperties xmlns='urn:schemas-microsoft-com:office:office'>"
+ "<Author>Unitech</Author><LastAuthor>Unitech</LastAuthor><Created></Created><LastSaved></LastSaved><Version>12.00</Version>"
+ "</DocumentProperties>");
//样式
sb.Append("<Styles>");
sb.Append("<Style ss:ID='header'>"
+ "<Font ss:FontName='宋体' x:CharSet='134' ss:Size='10' ss:Color='#000000' ss:Bold='0'/>"
+ "<Alignment ss:Horizontal='Center' ss:Vertical='Center'/>"
+ "<Interior ss:Color='#d8d8d8' ss:Pattern='Solid'/>"
+ "<Borders>"
+ "<Border ss:Position='Bottom' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Left' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Right' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Top' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "</Borders></Style>");
sb.Append("<Style ss:ID='body'>"
+ "<Font ss:FontName='宋体' x:CharSet='134' ss:Size='10' ss:Color='#000000'/>"
+ "<Alignment ss:Vertical='Center'/>"
+ "<NumberFormat ss:Format='@'/>"
+ "<Borders>"
+ "<Border ss:Position='Bottom' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Left' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Right' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "<Border ss:Position='Top' ss:LineStyle='Continuous' ss:Weight='1' ss:Color='#bfbfbf'/>"
+ "</Borders></Style>");
sb.Append("</Styles>");
//Work Sheet
sb.Append(worksheetXml);
sb.Append("</Workbook>");
return sb.ToString();
}
有需要的拿去自己进行改进和优化吧。
DataSet数据导出为Excel文档(每个DataTable为一个Sheet)的更多相关文章
- sqlserver将数据库的数据导成excel文档方法
sqlserver将数据库的数据导成excel文档方法 最近公司需要下载uniport的数据跟之前的数据进行对比,所以避免不了需要将数据库的数据导出来,把SQLServer表中的数据导出为Excel文 ...
- 如何将Revit明细表导出为Excel文档
Revit软件没有将明细表直接导出为Excel电子表格的功能,Revit只能将明细表导出为TXT格式,但是这种TXT文件用EXCEL处理软件打开然后另存为XLS格式即可,以Revit2013版自带的建 ...
- dataset数据导出到Excel
1.将数据写入HTTP输出流/这样子导出以后的数据全在一行中 public void CreateExcel(DataSet ds, string FileName) { HttpResponse r ...
- C# 将dataset数据导出到excel中
//添加引用 NPOI.dll //添加 using NPOI.HSSF.UserModel; /// <summary> /// 导出数据到Excel /// </summary& ...
- asp.net DataSet数据导出到Excel中
方法: [STAThread]///这是必须的 public override void VerifyRenderingInServerForm(System.Web.UI.Control co ...
- Java之Poi导出Excel文档
一.Poi简介 在后台管理系统中,我们经常要做的导出操作,通常导出为Excel文档的形式,而Poi则提供了这种需要的支持. 二.Workbook/HSSFWorkbook/XSSFWorkbook 1 ...
- C#操作Excel(2)-- 打开-读取Excel文档
由于要为某软件实现导出Excel功能,故有此文. 本文的开发环境是Visual Studio 2010 ,C#, Excel 2007. 新建C#工程后打开Solution Explorer,可以看到 ...
- jquery.table2excel,将HTML的table标签数据导出成excel
<!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content=&quo ...
- GrapeCity Documents for Excel 文档API组件 V2.2 新特性介绍
GrapeCity Documents for Excel 文档API组件 V2.2 正式发布,本次新版本包含诸多重量级产品功能,如:将带有形状的电子表格导出为 PDF.控制分页和电子表格内容.将Ex ...
随机推荐
- [改善Java代码]优先选择线程池
在Java1.5之前,实现多线程编程比较麻烦,需要自己启动线程,并关注同步资源,防止线程死锁等问题,在1.5版本之后引入了并行计算框架,大大简化了多线程开发. 我们知道线程有5个状态:新建状态(New ...
- C#入门教程(一)–.Net平台技术介绍、C#语言及开发工具介绍-打造C#学习教程
一.什么是.Net平台? .Net平台是微软搭建的技术平台,技术人员在此平台上进行应用的搭建与开发.它提供了运行所必须的环境.NET Framework类库以及CLR(公共语言运行时).好比我们人类的 ...
- HttpClient(4.3.5) - 简单示例
HttpClient 是一个客户端的 HTTP 传输库,而不是浏览器.HttpClient 的目的是传输和接收 HTTP 报文.HttpClient 不会尝试去处理报文内容,执行嵌入 HTML 内的 ...
- dreamweaver中用正则表达式查找替换批量删除 tppabs标签的方法
查找替换 正则表达式 \btppabs="h[^"]*" 后面不能有空格 你懂得的 选中右下角的 √[使用正则表达式] 替换全部
- Android之触屏事件
方法一: 新建"MyView"类 package onTouchEvent; import android.content.Context; import android.grap ...
- sqlserver2008 如何定时清理索引碎片
sqlserver2008 如何定时清理索引碎片 查询索引引起的表垃圾碎片sql脚本: SELECT object_name(a.object_id) [TableName] ,a.index_id ...
- FastSocket学习笔记~制定自已的传输协议
对于TCP或者UDP来说,它们作于传输层的协议,有着自己的标准,或者叫格式,在我们看TCP格式之前先了解一下计算机的基础知识,字节,它是计算机世界的一个小单位,也是我们可以理会到的,如一个utf-8英 ...
- CSS常见的浏览器前缀
为了让浏览器识别某些专属属性,有时候需要在CSS属性前增加浏览器前缀 -ms-:Microsoft IE -moz-:Mozilla Firefox -o-:Opera Opera -webkit-: ...
- 用angular实时获取本地localStorage数据,实现一个模拟后台数据登入的效果
研究了一上午,终于做出了,实时获取本地localStorage来模拟注册登入~~~ <!DOCTYPE html><html><head lang="en&qu ...
- mongoDB知识总结
官方说明文档:https://docs.mongodb.com/manual/mongo/ 1 NoSQL 简介 NoSQL,全称是”Not Only Sql”,指的是非关系型的数据库(相对于关系型数 ...