今天在做项目时,通过流导出数据到Excel却不显示网格线,真是郁闷。上网查了好久才得一良方(注意<XML>标签中的代码):

DataTable thisTable = DBHelper.GetDataTable("select * from table");string sheetName = "sheetName";string fileName = "fileName";if (thisTable != null){    StringWriter sw = new StringWriter();    sw.WriteLine("<html xmlns:x=\"urn:schemas-microsoft-com:office:excel\">");    sw.WriteLine("<head>");    sw.WriteLine("<!--[if gte mso 9]>");    sw.WriteLine("<xml>");    sw.WriteLine(" <x:ExcelWorkbook>");    sw.WriteLine("  <x:ExcelWorksheets>");    sw.WriteLine("   <x:ExcelWorksheet>");    sw.WriteLine("    <x:Name>" + sheetName + "</x:Name>");    sw.WriteLine("    <x:WorksheetOptions>");    sw.WriteLine("      <x:Print>");    sw.WriteLine("       <x:ValidPrinterInfo />");    sw.WriteLine("      </x:Print>");    sw.WriteLine("    </x:WorksheetOptions>");    sw.WriteLine("   </x:ExcelWorksheet>");    sw.WriteLine("  </x:ExcelWorksheets>");    sw.WriteLine("</x:ExcelWorkbook>");    sw.WriteLine("</xml>");    sw.WriteLine("<![endif]-->");    sw.WriteLine("</head>");    sw.WriteLine("<body>");    sw.WriteLine("<table>");    sw.WriteLine(" <tr>");    sw.WriteLine("  <td><strong>列名0</strong></td>");    sw.WriteLine("  <td>列名1</td>");    sw.WriteLine("  <td>列名2</td>");    sw.WriteLine("  <td>列名3</td>");    sw.WriteLine("  <td>列名4</td>");    sw.WriteLine("  <td>列名5</td>");    sw.WriteLine(" </tr>");    foreach (DataRow dr in thisTable.Rows)    {        sw.WriteLine(" <tr>");        sw.WriteLine("  <td>" + dr["C0"] + "</td>");        sw.WriteLine("  <td>" + dr["C1"] + "</td>");        sw.WriteLine("  <td>" + dr["C2"] + "</td>");        sw.WriteLine("  <td>" + dr["C3"] + "</td>");        sw.WriteLine("  <td>" + dr["C4"] + "</td>");        sw.WriteLine("  <td>" + dr["C5"] + "</td>");        sw.WriteLine(" </tr>");    }    sw.WriteLine("</table>");    sw.WriteLine("</body>");    sw.WriteLine("</html>");    sw.Close();    Response.Clear();    Response.Buffer = true;    Response.Charset = "UTF-8";    this.EnableViewState = false;    Response.AddHeader("Content-Disposition", "attachment; filename=" + fileName +".xls");    Response.ContentType = "application/ms-excel";    Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");    Response.Write(sw);    Response.End();}

C#导出EXCEL没有网格线的解决方法的更多相关文章

  1. SQL Server 导出Excel有换行的解决方法

    参考地址::https://vcoo.cc/blog/1234/ 从 SQL Server 查询结果中复制结果数据粘贴到 Excel 中存在这么个问题:如果字段内容中有换行符,那么粘贴到 Excel ...

  2. 64位系统web项目导出excel问题分析及解决方法汇总

    最近在web项目中做了一个导出Excel功能.在导出的时候报错:检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败. 一 ...

  3. phpexcel导出数字带E的解决方法

    phpexcel导出数字带E的解决方法 excel之所以带E 是因为按照数字格式来显示了(数字过长的时候) 数字左边或者右边加空格就变成字符串了 那么excel就会按照字符串格式来显示了 就不会带E了

  4. [转载]oracle 11g不能导出空表的多种解决方法

    原文地址:11g不能导出空表的多种解决方法">oracle 11g不能导出空表的多种解决方法作者:Anlin_Yang ORACLE 11g 用exp命令导出库文件备份时,发现只能导出 ...

  5. Xcode导出App一般问题及其解决方法(开发者协议变更及Bundle Id过期问题)

    Xcode导出App一般问题及其解决方法 问题一:开发者协议变更问题. 变更后打包会出现如下图A警告,此时点击 "visit developer website"进入Apple开发 ...

  6. 内存或磁盘空间不足 Microsoft Excel无法再次打开解决方法

    在网络上下载的文件,使用EXCEL打开的时候提示“内存或磁盘空间不足,Microsoft Excel 无法再次打开或保存任何文档.”,针对这个问题,装机之家小编特地在网上搜罗了具体解决方法,但是网上提 ...

  7. C#用ado.net访问EXCEL的常见问题及解决方法

    C#用ado.net访问EXCEL的常见问题及解决方法,除了像sql server,access常见的数据库,其实Excel文件也可以做为数据库访问. ado.net访问excel的实例: OleDb ...

  8. 使用POI导出EXCEL工具类并解决导出数据量大的问题

    POI导出工具类 工作中常常会遇到一些图表需要导出的功能,在这里自己写了一个工具类方便以后使用(使用POI实现). 项目依赖 <dependency> <groupId>org ...

  9. Java代码导入导出 Excel 表格最简单的方法

    import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStrea ...

随机推荐

  1. 个人工作中ssd、audio python脚本总结

    1.os.system(cmd)或者os.popen(cmd)调用外部命令 cmd中需要注意特殊字符的转义功能,如: USBSTOR\DISK&VEN_GENERIC-&PROD_SD ...

  2. Java web AJAX入门

    一:AJAX简介 AJAX :Asynchronous JavaScript And XML 指异步 JavaScript 及 XML 一种日渐流行的Web编程方式 Better Faster Use ...

  3. MVC中使用Echart后台加载数据 实现饼图、折线图、全国地图数据,单击双击事件等

    @{ Layout = null; } @if (false) { <script src="~/Js/jquery-easyui-1.5/jquery.min.js"> ...

  4. (转)Java Socket编程

    原文出自:http://www.cnblogs.com/rocomp/p/4790340.html Socket是网络驱动层提供给应用程序编程接口和一种机制.可以把Socket比喻成一个港口码头,应用 ...

  5. JAVA基础知识总结:五

    一.初步认识数组 1.理解数组 数组是用来存储相兼容数据类型的定长的容器 特点: a.只能存放相兼容数据类型,不能存放多种数据类型 b.可以存放基本数据类型和引用数据类型 c.数组是定长的,一旦被初始 ...

  6. yii2布局选择与属性标签设置

    Yii选择布局的方法: 1. 通过控制器成员变量设置: public $layout = false;//不使用布局 public $layout = 'main';//设置使用的布局文件(@app/ ...

  7. 基于.NET CORE微服务框架 -浅析如何使用surging

    1.前言 surging受到大家这么强烈的关注,我感到非常意外,比如有同僚在公司的分享会上分享surging, 还有在博客拿其它的RPC框架,微服务做对比等等,这些举动都让我感觉压力很大,毕竟作为个人 ...

  8. Android Weekly Notes Issue #281

    October 29th, 2017 Android Weekly Issue #281 本期内容不多,包含了小众DI库牙签帮助测试的文章,Kotlin中Delegate的强大之介绍,以及基于Goog ...

  9. HDU 6055 Regular polygon

    Regular polygon Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  10. Is It A Tree?

    Is It A Tree? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...