从GridView导出到Excel不能正确显示波斯语

时间:2016-02-29 09:58:53

标签: excel sql-server-2008 utf-8 export unicode-string

通过SqlDataSource绑定GridView,我写下以下代码从GridView导出到Excel:

System.IO.StringWriter sw = new System.IO.StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.ContentType = "application/vnd.ms-excel";
Response.AddHeader("Content-Disposition", "attachment;filename=" + FileName);
gvReportPrint.GridLines = GridLines.Both;
gvReportPrint.Font.Name = "'BYekan'";

foreach (GridViewRow row in gvReportPrint.Rows)
{
    row.Cells[2].Attributes.Add("class", "textmode");
}

string style = @"<style> .textmode { mso-number-format:\@; } </style>";
gvReportPrint.HeaderStyle.Font.Bold = true;
Response.Write(style);
gvReportPrint.RenderControl(hw);
Response.Output.Write(sw.ToString());
Response.End();

从GridView导出到Excel期间,unicode字符无法正确显示, 它们显示如下: --> Click this link to show the problem <--

1 个答案:

答案 0 :(得分:0)

您似乎正在使用asp:GridView,我遇到了同样的问题,使用GridView class解决了它,如下所示:

public void ToExcel(DataTable dt, string reportName)
    {
        if (dt.Rows.Count > 0)
        {
            string filename = string.Format("{0}.xls", reportName);

            GridView gv = new GridView();

            gv.DataSource = dt;
            gv.HeaderStyle.BackColor = System.Drawing.Color.FromArgb(0, 119, 179);
            gv.HeaderStyle.ForeColor = System.Drawing.Color.FromArgb(250, 250, 250);
            gv.AlternatingRowStyle.BackColor = System.Drawing.Color.FromArgb(191, 191, 191);
            gv.Font.Name = "Tahoma";
            gv.Font.Size = 10;
            gv.DataBind();

            System.IO.StringWriter sw = new System.IO.StringWriter();
            HtmlTextWriter hw = new HtmlTextWriter(sw);
            HttpContext.Current.Response.Cache.SetCacheability(HttpCacheability.NoCache);
            HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
            HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment;filename=" + filename);
            HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.Unicode;
            HttpContext.Current.Response.BinaryWrite(System.Text.Encoding.Unicode.GetPreamble());

            gv.RenderControl(hw);
            HttpContext.Current.Response.Output.Write(sw.ToString());
            HttpContext.Current.Response.End();
        }
    }

dt应该是gridview的数据源。

另请注意ASP.NET Excel export encoding problem