关于ASP.NET 将数据导出成Excel 的总结[下]

简介:

使用ExcelHelper 封装类,将DataSet 输出成Excel文件的多个Sheet 页。

使用代码如下:

复制代码
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load( object sender, EventArgs e)
{
btn.Click += new EventHandler(btn_Click);
Button1.Click += new EventHandler(Button1_Click);
}

void Button1_Click( object sender, EventArgs e)
{
var ds = new DataSet();
var dt = new DataTable( " TableName For Sheet1 ");
dt.Columns.Add( " col1 ");
dt.Columns.Add( " col2 ");
dt.Rows.Add( " Value1 ", " Value2 ");

var dt2 = new DataTable( " TableName For Sheet2 ");
dt2.Columns.Add( " col1 ");
dt2.Columns.Add( " col2 ");
dt2.Rows.Add( " Value1 ", " Value2 ");
ds.Tables.Add(dt);
ds.Tables.Add(dt2);
ExcelHelper.ToExcel(ds, " test.xls ", Page.Response);
}

void btn_Click( object sender, EventArgs e)
{
var ds = new DataSet();
DataTable dt = new DataTable();
dt.Columns.Add( " col ");
ds.Tables.Add(dt);
ExcelHelper.ToExcel(ds, " test.xls ", Page.Response);
}
}
复制代码


ExcelHelper.cs 封装类,源代码如下:
复制代码
// ExcelHelper.cs

public class ExcelHelper
{
// Row limits older Excel version per sheet
const int rowLimit = 65000;

private static string getWorkbookTemplate()
{
var sb = new StringBuilder();
sb.Append( " <xml version>\r\n<Workbook
xmlns=\ " urn:schemas-microsoft-com:office:spreadsheet\"\r\n ");
sb.Append( " xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\n
xmlns:x=\ " urn:schemas- microsoft-com:office:excel\"\r\n
xmlns:ss=\ " urn:schemas-microsoft-com:office:spreadsheet\">\r\n ");
sb.Append( " <Styles>\r\n
<Style ss:ID=\ " Default\" ss:Name=\"Normal\">\r\n
<Alignment ss:Vertical=\ " Bottom\"/>\r\n <Borders/> ");
sb.Append( " \r\n <Font/>\r\n <Interior/>\r\n <NumberFormat/>\r\n
<Protection/>\r\n </Style>\r\n
<Style ss:ID=\ " BoldColumn\">\r\n <Font ");
sb.Append( " x:Family=\"Swiss\" ss:Bold=\"1\"/>\r\n </Style>\r\n
<Style ss:ID=\ " s62\">\r\n <NumberFormat ");
sb.Append( " ss:Format=\"@\"/>\r\n </Style>\r\n
<Style ss:ID=\ " Decimal\">\r\n
<NumberFormat ss:Format=\ " 0.0000\"/>\r\n </Style>\r\n ");
sb.Append( " <Style ss:ID=\"Integer\">\r\n
<NumberFormat ss:Format=\ " 0\"/>\r\n </Style>\r\n
<Style ss:ID=\ " DateLiteral\">\r\n <NumberFormat ");
sb.Append( " ss:Format=\"mm/dd/yyyy;@\"/>\r\n </Style>\r\n
<Style ss:ID=\ " s28\">\r\n ");
sb.Append( " <Alignment ss:Horizontal=\"Left\" ss:Vertical=\"Top\"
ss:ReadingOrder=\ " LeftToRight\" ss:WrapText=\"1\"/>\r\n ");
sb.Append( " <Font x:CharSet=\"1\" ss:Size=\"9\"
ss:Color=\ " #808080\" ss:Underline=\"Single\"/>\r\n ");
sb.Append( " <Interior ss:Color=\"#FFFFFF\" ss:Pattern=\"Solid\"/>

</Style>\r\n</Styles>\r\n { 0}</Workbook> " );
return sb.ToString();
}

private static string replaceXmlChar( string input)
{
input = input.Replace( " & ", " & ");
input = input.Replace( " < ", " < ");
input = input.Replace( " > ", " > ");
input = input.Replace( " \" ", """ );
input = input.Replace( " ' ", " ' ");
return input;
}

private static string getWorksheets(DataSet source)
{
var sw = new StringWriter();
if (source == null || source.Tables.Count == 0)
{
sw.Write( " <Worksheet ss:Name=\"Sheet1\"><Table><Row>

<Cell ss:StyleID=\ " s62\"><Data ss:Type=\"String\"></Data>
</Cell></Row></Table></Worksheet> " );
return sw.ToString();
}
foreach (DataTable dt in source.Tables)
{
if (dt.Rows.Count == 0)
sw.Write( " <Worksheet ss:Name=\" " + replaceXmlChar(dt.TableName) +
" \"><Table><Row><Cell ss:StyleID=\"s62\">

<Data ss:Type=\ " String\"></Data></Cell></Row>
</Table></Worksheet> " );
else
{
// write each row data
var sheetCount = 0;
for ( int i = 0; i < dt.Rows.Count; i++)
{
if ((i % rowLimit) == 0)
{
// add close tags for previous sheet of the same data table
if ((i / rowLimit) > sheetCount)
{
sw.Write( " </Table></Worksheet> ");
sheetCount = (i / rowLimit);
}
sw.Write( " <Worksheet ss:Name=\" " +
replaceXmlChar(dt.TableName) +
(((i / rowLimit) == 0) ? "" :
Convert.ToString(i / rowLimit)) + " \"><Table> ");
// write column name row
sw.Write( " <Row> ");
foreach (DataColumn dc in dt.Columns)
sw.Write(
string.Format(
" <Cell ss:StyleID=\"BoldColumn\">

<Data ss:Type=\ " String\">{0}</Data></Cell> ",
replaceXmlChar(dc.ColumnName)));
sw.Write( " </Row>\r\n ");
}
sw.Write( " <Row>\r\n ");
foreach (DataColumn dc in dt.Columns)
sw.Write(
string.Format(
" <Cell ss:StyleID=\"s62\"><Data ss:Type=\"String\">

{ 0}</Data></Cell> " ,
replaceXmlChar
(dt.Rows[i][dc.ColumnName].ToString())));
sw.Write( " </Row>\r\n ");
}
sw.Write( " </Table></Worksheet> ");
}
}

return sw.ToString();
}
public static string GetExcelXml(DataTable dtInput, string filename)
{
var excelTemplate = getWorkbookTemplate();
var ds = new DataSet();
ds.Tables.Add(dtInput.Copy());
var worksheets = getWorksheets(ds);
var excelXml = string.Format(excelTemplate, worksheets);
return excelXml;
}

public static string GetExcelXml(DataSet dsInput, string filename)
{
var excelTemplate = getWorkbookTemplate();
var worksheets = getWorksheets(dsInput);
var excelXml = string.Format(excelTemplate, worksheets);
return excelXml;
}

public static void ToExcel
(DataSet dsInput, string filename, HttpResponse response)
{
var excelXml = GetExcelXml(dsInput, filename);
response.Clear();
response.AppendHeader( " Content-Type ", " application/vnd.ms-excel ");
response.AppendHeader
( " Content-disposition ", " attachment; filename= " + filename);
response.Write(excelXml);
response.Flush();
response.End();
}

public static void ToExcel
(DataTable dtInput, string filename, HttpResponse response)
{
var ds = new DataSet();
ds.Tables.Add(dtInput.Copy());
ToExcel(ds, filename, response);
}
}
复制代码
来源:http://www.codeproject.com/KB/office/ExportDataSetToExcel.aspx

Demo下载



本文转自钢钢博客园博客,原文链接:http://www.cnblogs.com/xugang/archive/2011/09/26/2191686.html,如需转载请自行联系原作者
作者: XuGang 网名:钢钢
出处: http://xugang.cnblogs.com

相关文章
|
7天前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
49 8
|
2月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
2月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
305 10
|
3月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
50 1
|
3月前
|
数据格式 UED
记录一次NPOI库导出Excel遇到的小问题解决方案
【11月更文挑战第16天】本文记录了使用 NPOI 库导出 Excel 过程中遇到的三个主要问题及其解决方案:单元格数据格式错误、日期格式不正确以及合并单元格边框缺失。通过自定义单元格样式、设置数据格式和手动添加边框,有效解决了这些问题,提升了导出文件的质量和用户体验。
328 3
|
3月前
|
Java API Apache
|
3月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
172 4
|
4月前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
225 6
|
4月前
|
SQL XML 关系型数据库
入门指南:利用NHibernate简化.NET应用程序的数据访问
【10月更文挑战第13天】NHibernate是一个面向.NET的开源对象关系映射(ORM)工具,它提供了从数据库表到应用程序中的对象之间的映射。通过使用NHibernate,开发者可以专注于业务逻辑和领域模型的设计,而无需直接编写复杂的SQL语句来处理数据持久化问题。NHibernate支持多种数据库,并且具有高度的灵活性和可扩展性。
72 2
|
4月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
268 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档

热门文章

最新文章