/// <summary>
/// DataSet导出Excel
/// </summary>
/// <param name="arrTitle">列标题,若为null,则直接取dataset列标题</param>
/// <param name="ds">要导出的DataSet</param>
/// <param name="fileName">Excel文件名,不需要传入扩展名</param>
protected void CreateExcel(string[] arrTitle, DataSet ds, string fileName)
{
StringBuilder strb = new StringBuilder();
strb.Append(" <html xmlns:o=\"urn:schemas-microsoft-com:office:office\"");
strb.Append("xmlns:x=\"urn:schemas-microsoft-com:office:excel\"");
strb.Append("xmlns=\"http://www.w3.org/TR/REC-html40\"");
strb.Append(" <head> <meta http-equiv='Content-Type' content='text/html; charset=gb2312'>");
strb.Append(" <style>");
strb.Append(".xl26");
strb.Append(" {mso-style-parent:style0;");
strb.Append(" font-family:\"Times New Roman\", serif;");
strb.Append(" mso-font-charset:0;");
strb.Append(" mso-number-format:\"@\";}");
strb.Append(" </style>");
strb.Append(" <xml>");
strb.Append(" <x:ExcelWorkbook>");
strb.Append("  <x:ExcelWorksheets>");
strb.Append("  <x:ExcelWorksheet>");
strb.Append("    <x:Name>Sheet1 </x:Name>");
strb.Append("    <x:WorksheetOptions>");
strb.Append("    <x:DefaultRowHeight>285 </x:DefaultRowHeight>");
strb.Append("    <x:Selected/>");
strb.Append("    <x:Panes>");
strb.Append("      <x:Pane>");
strb.Append("      <x:Number>3 </x:Number>");
strb.Append("      <x:ActiveCol>1 </x:ActiveCol>");
strb.Append("      </x:Pane>");
strb.Append("    </x:Panes>");
strb.Append("    <x:ProtectContents>False </x:ProtectContents>");
strb.Append("    <x:ProtectObjects>False </x:ProtectObjects>");
strb.Append("    <x:ProtectScenarios>False </x:ProtectScenarios>");
strb.Append("    </x:WorksheetOptions>");
strb.Append("  </x:ExcelWorksheet>");
strb.Append("  <x:WindowHeight>6750 </x:WindowHeight>");
strb.Append("  <x:WindowWidth>10620 </x:WindowWidth>");
strb.Append("  <x:WindowTopX>480 </x:WindowTopX>");
strb.Append("  <x:WindowTopY>75 </x:WindowTopY>");
strb.Append("  <x:ProtectStructure>False </x:ProtectStructure>");
strb.Append("  <x:ProtectWindows>False </x:ProtectWindows>");
strb.Append(" </x:ExcelWorkbook>");
strb.Append(" </xml>");
strb.Append("");
strb.Append(" </head> <body> <table align=\"center\" style='border-collapse:collapse;table-layout:fixed'> <tr>");

if (ds.Tables.Count > 0)
{
//写列标题  
if (arrTitle != null && arrTitle.Length > 0)
{
foreach (string strCol in arrTitle)
{
strb.Append(" <td> <b>" + strCol + " </b> </td>");
}
strb.Append(" </tr>");
}
else
{
int columncount = ds.Tables[0].Columns.Count;
for (int columi = 0; columi < columncount; columi++)
{
strb.Append(" <td> <b>" + ds.Tables[0].Columns[columi] + " </b> </td>");
}
strb.Append(" </tr>");
}

//写数据     
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
strb.Append(" <tr>");
for (int j = 0; j < ds.Tables[0].Columns.Count; j++)
{
strb.Append(" <td class='xl26'>" + ds.Tables[0].Rows[i][j].ToString() + " </td>");
}
strb.Append(" </tr>");
}
}
strb.Append(" </body> </html>");
Response.Clear();
Response.Buffer = true;
Response.Charset = "GB2312";
Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8) + ".xls");
Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//设置输出流为简体中文   
Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。   
this.EnableViewState = false;
Response.Write(strb);
Response.End();
}

转载于:https://www.cnblogs.com/taizhouxiaoba/archive/2011/07/21/2112693.html

DataSet数据导入到Excel相关推荐

  1. 在asp中如何把表格数据导入到Excel里

      在不久前,才使用asp的winform做了一个小型项目.其中就有遇到这个问题.如何把表格里的数据导入到Excel里,一开始想的是把gridview里的内容直接导入到Excel里,后来发现效果并不理 ...

  2. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】)...

     本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较    (三)SSIS的简介    (四)数据库中存储过程示例(SSIS应用需要) (五)Excel模板的制作(这步这么简单,稍微介 ...

  3. Java实现Excel导入数据库,数据库中的数据导入到Excel

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 实现的功能: Java实现Excel导入数据库,如果存在就更新 数据库中的数据导入到Excel 1. ...

  4. 如何在ex表格导入php_怎么使用php把表格中的数据导入到excel中,php如何快速导入excel表格数据...

    php怎么导入大量数据的excel php导出数据的Excel: PHP从数据库分多次读取100万行记录,和分将100万入文本文件都没问题 Excel可以支100万行记录,Excel 2003最大支持 ...

  5. 数据导入(excel读取,存储进数据库【多表】)

    QQ:1187362408 欢迎技术交流和学习 数据导入(excel读取,存储进数据库[多表]),业务需求 TODO: 1,选择导入地区 2,数据校验: (角色类别[1]:一个用户具有多角色      ...

  6. MSSQL数据导入导出Excel的相关代码

    MSSQL数据导入导出Excel的相关代码 参考: https://www.sqlteam.com/forums/topic.asp?TOPIC_ID=49926 1 Export data to e ...

  7. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转...

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])  本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较    ( ...

  8. Excel - 将 TXT 数据导入到 Excel 中(自动将数据拆分成多列)

    txt文本: 将txt格式里的两列数据复制粘贴导入excel 后全都在同一列. 通过下述操作, 可以将 TXT 数据导入到 Excel 中,并且自动拆分为两列. 数据→从文本

  9. C#窗体将DGV控件中数据导入导出Excel表

    目录 界面图: 效果视频: 一:将DGV数据导出到Excel表中 二:将Excel表数据导入到DGV中 三:界面全部代码 界面图: 效果视频: DGV数据导入导出Excel 一:将DGV数据导出到Ex ...

最新文章

  1. FreeWheel基于Go的实践经验漫谈——GC是大坑(关键业务场景不用),web框架尚未统一,和c++性能相比难说...
  2. 免费学python的软件-此贴告诉你:为啥shell脚本人,不建议学python
  3. java 实现自旋锁_java自旋锁的代码实现
  4. CF815D Karen and Cards
  5. Windows8.1硬盘安装Ubuntu14.04以及卸载Ubuntu14.04参考教程[图]
  6. [BZOJ]2820: YY的GCD
  7. ZOJ 3810 A Volcanic Island (2014年牡丹江赛区网络赛B题)
  8. Windows下部署yolov5实现口罩检测
  9. oracle XDB和XPT
  10. Android快速开发(2)
  11. brctl 设置ip_Linux网桥配置命令:brctl
  12. 【保姆级入门系列】阿ken教你学Python(六) ——组合数据类型
  13. GEE-Python遥感大数据分析、管理与可视化
  14. Android 通过 WebView 请求下载 APK
  15. 2019年最值得学习的编程语言TOP5
  16. Unity减少安装包的大小总结
  17. 图书信息管理系统(二)
  18. 【AD封装】2.54间距排针排母插件贴片(带3D)
  19. 简练软考知识点整理-实施整体变更控制过程
  20. vc 触摸屏电脑 显示触摸屏软键盘

热门文章

  1. 2016蓝桥杯C++A:网友年龄
  2. bzoj 3209: 花神的数论题 喵哈哈村的秘境探险(四)
  3. NYOJ 61:传纸条(一)(三维DP)
  4. scipy.misc.imresize
  5. HBase因hostname可能引起的RIT问题。HBASE的ip和hostname坑
  6. 记录zedboard无法识别com的解决思路
  7. fpga与三八译码器(BASYS3 VIVADO18)
  8. svg的transform-matrix详解
  9. vue-cli3+cordova实现app混合开发
  10. iOS开发之一句代码检测APP版本的更新