ASP.NET Excel导出编码问题
发布时间:2020-07-21 10:34:52 所属栏目:asp.Net 来源:互联网
导读:我在ASP.NET网站上做了一些Excel导出。 一切工作除了编码。当我在Excel中打开它,它看起来像这样: Eingabe Kosten je Ger¤t Ger¤t: Ger¤tebezeichnung: Betriebsmittel Heizl in : 4 Dieselverbrauch in : 4 这是我的代码: Response.Clear();Respon
|
我在ASP.NET网站上做了一些Excel导出。
这是我的代码: Response.Clear();
Response.ContentType = "application/ms-excel";
Response.AddHeader("Content-Disposition","inline;filename=NachkalkGeraete.xls;");
var writer = new HtmlTextWriter(Response.Output);
SomeControl.RenderControl(writer); /* FormView,Table,DataGrid... */
Response.End();
我已经尝试明确设置Encoding ..但没有发生变化: Response.Clear();
Response.ContentType = "application/vnd.ms-excel";
Response.AddHeader("Content-Disposition","attachment; filename=NachkalkGeraete.xls");
Response.BufferOutput = true;
Response.ContentEncoding = System.Text.Encoding.UTF8;
Response.Charset = "UTF-8";
EnableViewState = false;
System.IO.StringWriter tw = new System.IO.StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(tw);
SomeControl.RenderControl(hw);
Response.Write(tw.ToString());
Response.End();
有什么问题吗? 解决方法好吧,我发现,问题可能在excel文件的标题,它不包含BOM字节序列(在文件的开头表示使用的编码)。所以我这样做,它适用于我: Response.Clear();
Response.AddHeader("content-disposition","attachment;filename=Test.xls");
Response.ContentType = "application/ms-excel";
Response.ContentEncoding = System.Text.Encoding.Unicode;
Response.BinaryWrite(System.Text.Encoding.Unicode.GetPreamble());
System.IO.StringWriter sw = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter hw = new HtmlTextWriter(sw);
FormView1.RenderControl(hw);
Response.Write(sw.ToString());
Response.End(); (编辑:长春站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net – Azure可以运行WPF吗?
- asp.net – @ Url.Action在控制器中创建空值的参数之间添加
- asp.net-mvc – ASP.Net MVC是否运行在ASP.NET 2.0之上?
- ASP.NET通过自定义函数实现对字符串的大小写切换功能
- asp.net-mvc – 发现MVC项目中是否使用views / partials
- ASP.NET中上传并读取Excel文件数据示例
- asp.net-mvc – 什么时候使用ViewData而不是ViewModels?
- 充分利用ASP.NET的三种缓存提高站点性能的注意方法
- 数组 – 如何在vbscript中实现具有可变大小的数组
- asp.net – 脚本标签和链接标签进入asp:内容或外部
