asp.net导出Excel格式数据方案
来源:互联网 发布:中国历年gdp数据excel 编辑:程序博客网 时间:2024/06/09 16:51
导出到Excel文件并不难,所以就有好多方法:控件直接Render、把DataSet输出成String再Write出来等,(当然如果调用Excel程序的库文件的话还可以使用更强的直接操作Excel的方法,但这种方法用于Web服务显得有点要求太高:必须让Web服务器安装指定版本的Excel或其支持库文件)。就其前两种方法,实际上也是一样的,Render也是把由DataSet转变的View生成为一个Table输出到客户端而已,只不过隐藏了细节,如果不信,你用EditPlus什么的看看生成的.xls文件就知道了。
Excel的识别力太强了,以至于它本身的格式、Csv格式、Tab分隔符格式、网页的Table格式等都能够很好的打开。但是它“太聪明”了,以至于自动识别数字和字符串,而且要把超过11位的数字自动变为科学计数法的格式,你试试输入“123456789012”,离开那个单元格,就成“123457E+11”了,够聪明的吧,不过有时会让我们感觉不便,因为我输入的就是我自己的身份证号码,尾巴上没有“X”,本来好好的15位数字,得现在成这么个计数法了。那我就改改显示格式吧,改为把数字显示为文本,好了。可是国家的身份证升级了,号码变成18位,我把它输入到数据库,导出来时,用刚才的方法处理过,18位没错,可是最后三位怎么都是零了!Excel为我们做了太多的事,不管是应该的还是不应该的。
怎么解决?请看代码:
private void Export(GridView GV, string FileType, string FileName)
{
Response.Charset = "UTF8";
Response.ContentEncoding = System.Text.Encoding.UTF8;
Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());
Response.ContentType = FileType;
this.EnableViewState = false;
Response.Write(PubFuncs.GridViewToExportTable(GV));
Response.End();
}
public static string ExportTable(DataTable dt)
{
string data = "";
data += "<table cellspacing=/"0/" cellpadding=/"5/" rules=/"all/" border=/"1/">";
//写出列名
data += "<tr style=/"font-weight: bold; white-space: nowrap;/">";
foreach (DataColumn column in dt.Columns)
{
data += "<td>" + column.ColumnName + "</td>";
}
data += "</tr>";
//写出数据
foreach (DataRow row in dt.Rows)
{
data += "<tr>";
foreach (DataColumn column in dt.Columns)
{
if (GetIsNumber(row[column].ToString()))
{
data += "<td style=/"vnd.ms-excel.numberformat:@/">" + row[column].ToString() + "</td>";
}
else
{
data += "<td>" + row[column].ToString() + "</td>";
}
}
data += "</tr>";
}
data += "</table>";
return data;
}
public static string GridViewToExportTable(GridView gv)
{
string data = "";
data += "<table cellspacing=/"0/" cellpadding=/"5/" rules=/"all/" border=/"1/">";
//写出列名
data += "<tr style=/"font-weight: bold; white-space: nowrap;/">";
for (int i = 0; i < gv.HeaderRow.Cells.Count; i++)
{
data += "<td>" + gv.HeaderRow.Cells[i].Text.ToString() + "</td>";
}
data += "</tr>";
//写出数据
for (int i = 0; i < gv.Rows.Count; i++)
{
data += "<tr>";
for (int j = 0; j < gv.Rows[i].Cells.Count; j++)
{
string strvlue = gv.Rows[i].Cells[j].Text.Trim().Replace(" ", "");
if (GetIsNumber(strvlue))
{
data += "<td style=/"vnd.ms-excel.numberformat:@/">" + strvlue + "</td>";
}
else
{
data += "<td>" + strvlue + "</td>";
}
}
data += "</tr>";
}
data += "</table>";
return data;
}
- asp.net导出Excel格式数据方案
- asp.net导出Excel/Csv格式数据方案
- [转]asp.net导出Excel/Csv格式数据最优方案(C#)
- asp.net导出Excel/Csv格式数据最优方案(C#)
- asp.net导出Excel/Csv格式数据最优方案(C#)
- asp.net导出Excel/Csv格式数据最优方案(C#)
- asp.net导出Excel/Csv格式数据最优方案(C#)
- asp.net中导出到Excel的方法汇总及导出Excel/Csv格式数据最优方案(C#)
- asp.net中导出到Excel的方法汇总及导出Excel/Csv格式数据最优方案(C#)
- asp.net中导出到Excel的方法汇总及导出Excel/Csv格式数据最优方案
- Asp.Net 导出 Excel 数据的9种方案
- Asp.Net 导出 Excel 数据的9种方案
- Asp.Net 导出 Excel 数据的9种方案
- 【译】Asp.Net 导出 Excel 数据的9种方案
- Asp.net导出Excel/Csv文本格式数据
- Asp.net导出Excel/Csv文本格式数据
- asp.net导出Excel数据
- ASP.net数据导出excel
- SNMP4J教程[转]
- 使用XmlDocument创建XML文档及增加删除更新节点
- Magento的block重写规则
- How To Automate Cleanup Of Dead Connections And INACTIVE Sessions [ID 206007.1]
- 绚丽的Jquery, CSS, MooTools 和 JS的导航菜单
- asp.net导出Excel格式数据方案
- 成功创业者的重要特质
- 每天只问小孩四句话
- LinkedHashSet
- 如何获得他人的信任
- 做web开发的算不算是真正意义上的程序员?
- SQL语句大全
- 对最近遇到的一些BT问题总结
- 业务实现数据导出为TXT文件