代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Asp.Net
】
GridView导出Excel(解决Excel空白没有网格)
作者:
Dezai.CN
/ 发布于
2011/12/27
/
806
收录一种GridView导出Excel的方法,也是网上最常见的一种,但导出的Excel出现背景空白没有网格现象,后来明白这种方法不是真正的导出Excel,实际上是html,只是用Excel打开罢了
<div>private void toexcel(string title)</div> { GridView1.AllowPaging = false; //先锁定分页 string sqlstr1 = "select * from HouseApp where YGS_Time is null"; CAN.ExecGridViewBind(GridView1, sqlstr1); //这里要绑定数据,这是我的方法,请写成你自己的 Response.Clear(); Response.Buffer = false; Response.Charset = "utf-8"; Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(title) + ".xls"); Response.ContentEncoding = System.Text.Encoding.UTF8; Response.ContentType = "application/ms-excel"; Response.Write("<meta http-equiv=Content-Type content=\"text/html; charset=utf-8\">"); this.EnableViewState = false; System.IO.StringWriter oStringWriter = new System.IO.StringWriter(); HtmlTextWriter oHtmlTextWriter = new HtmlTextWriter(oStringWriter); GridView1.RenderControl(oHtmlTextWriter);// 数字字符导Excel后转Text格式,否则前面的 0 字符会自动舍弃 Response.Write(AddExcelHead()); Response.Write(oStringWriter.ToString()); Response.Write(AddExcelbottom()); Response.End(); GridView1.AllowPaging = true; //恢复分页 //为GridView重新绑定数据源 string sqlstr = "select * from HouseApp where YGS_Time is null"; CAN.ExecGridViewBind(GridView1, sqlstr); } protected void Button1_Click(object sender, EventArgs e) { toexcel("文件名"); } public static string AddExcelHead() { StringBuilder sb = new StringBuilder(); sb.Append("<html xmlns:x=\"urn:schemas-microsoft-com:office:excel\">"); sb.Append(" <head>"); sb.Append(" <!--[if gte mso 9]><xml>"); sb.Append("<x:ExcelWorkbook>"); sb.Append("<x:ExcelWorksheets>"); sb.Append("<x:ExcelWorksheet>"); sb.Append("<x:Name></x:Name>"); sb.Append("<x:WorksheetOptions>"); sb.Append("<x:Print>"); sb.Append("<x:ValidPrinterInfo />"); sb.Append(" </x:Print>"); sb.Append("</x:WorksheetOptions>"); sb.Append("</x:ExcelWorksheet>"); sb.Append("</x:ExcelWorksheets>"); sb.Append("</x:ExcelWorkbook>"); sb.Append("</xml>"); sb.Append("<![endif]-->"); sb.Append(" </head>"); sb.Append("<body>"); return sb.ToString(); } public static string AddExcelbottom() { StringBuilder sb = new StringBuilder(); sb.Append("</body>"); sb.Append("</html>"); return sb.ToString(); } //重新下面方法解决错误:类型GridView的控件GridView1必须放置在具有runat=server的窗体标记内 public override void VerifyRenderingInServerForm(Control control) { }
试试其它关键字
导出Excel
同语言下
.
gzip压缩
.
实现http多线程断点续传下载文件
.
实现多线程断点续传下载大文件
.
生成字符串的 CheckSum
.
根据 UserAgent 获取浏览器的类型和版本
.
根据 Agent 判断是否是智能手机
.
隐藏手机号中间四位为*方法
.
合并图片(二维码和其他图片合并)
.
ASP.NET CORE中判断是否移动端打开网页
.
ASP.NET(C#)实现页面计时(定时)自动跳转
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3