Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/292.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 从asp.net c打开.xls文件时出错#_C#_Asp.net - Fatal编程技术网

C# 从asp.net c打开.xls文件时出错#

C# 从asp.net c打开.xls文件时出错#,c#,asp.net,C#,Asp.net,当我想将数据从datagrid导出到excel时,我有这段代码。 数据来自SQL。我正在使用ASP.NET C# 导出时,会产生一个警告/错误: 尽管我通过修改注册表来搜索解决方案 我不想修改注册表,因为配置每个浏览器用户会非常麻烦 你能帮我吗?gv.RenderControl(htw) 您只是将HTML文本文件伪装成XLS文件发送到客户端浏览器,当然Excel会抱怨 正如Lasse所指出的,文件不会通过指定扩展名而神奇地改变其格式。查看可用的库,例如,寻找用任何表格数据创建Excel格式文

当我想将数据从datagrid导出到excel时,我有这段代码。 数据来自SQL。我正在使用ASP.NET C#

导出时,会产生一个警告/错误:

尽管我通过修改注册表来搜索解决方案

我不想修改注册表,因为配置每个浏览器用户会非常麻烦

你能帮我吗?

gv.RenderControl(htw)

您只是将HTML文本文件伪装成XLS文件发送到客户端浏览器,当然Excel会抱怨

正如Lasse所指出的,文件不会通过指定扩展名而神奇地改变其格式。查看可用的库,例如,寻找用任何表格数据创建Excel格式文件的正确方法


此外,您还应该将文件从ASHX通用处理程序发送到浏览器,该处理程序绕过了大多数ASP.NET页面生命周期内容,这样您就不必在响应中处理任何排队输出。

看起来您实际上并没有将其保存为Excel格式,只是为其提供了.xls扩展名。我缺少什么?xls是旧版excel,旧版excel。改用xlsx。简而言之,在源位置将文件重命名为xlsx。可能有用。我已经尝试过@Ryios,但仍然是相同的警告/错误。您有任何解决方案吗?@LasseV.Karlsen除了第三方库之外,还有其他选项吗?有没有其他不涉及任何开源库的解决方案?@Juran,如果服务器上安装了Excel,您可以在不使用第三方库的情况下进行互操作。服务器上已经安装了excel,但这种情况仍然存在。我说,如果安装了excel,您可以这样做。你所做的永远不会成功。
 protected void ExportToExcel()
    {
        GridView gv = new GridView();
        Response.Clear();
        Response.Buffer = true;
        Response.ContentType = "application/vnd.ms-excel";
        Response.AddHeader("content-disposition", "attachment;filename=Serials.xls");
        Response.Charset = "";
        this.EnableViewState = false;

        System.IO.StringWriter sw = new System.IO.StringWriter();
        System.Web.UI.HtmlTextWriter htw = new System.Web.UI.HtmlTextWriter(sw);

        dt = new DataTable();
        dt = RetrieveResultsTable();
        //gv.AlternatingRowStyle.BackColor = Color. #CCFFFF
        gv.AlternatingRowStyle.BackColor = Color.FromArgb(204, 255, 255);
        gv.DataSource = dt;
        gv.DataBind();
        gv.RenderControl(htw);

        Response.Write(sw.ToString());
        Response.Flush();
        Response.Close();
        Response.End();
    }