我需要在HTTP响应中发送一个CSV文件。如何将输出响应设置为CSV格式?

这是行不通的:

Response.ContentType = "application/CSV";

当前回答

如上所述设置内容类型和内容配置会在不同的浏览器中产生截然不同的结果:

IE8:按需要保存对话框,Excel为默认应用程序。100%好。

Firefox:保存对话框确实显示,但Firefox不知道它是一个电子表格。建议用Visual Studio打开它!50%的好

Chrome:提示完全被忽略。CSV数据显示在浏览器中。0%的好。

当然,在所有这些情况下,我指的是浏览器,因为它们没有自定义的mime/应用程序映射。

其他回答

如上所述设置内容类型和内容配置会在不同的浏览器中产生截然不同的结果:

IE8:按需要保存对话框,Excel为默认应用程序。100%好。

Firefox:保存对话框确实显示,但Firefox不知道它是一个电子表格。建议用Visual Studio打开它!50%的好

Chrome:提示完全被忽略。CSV数据显示在浏览器中。0%的好。

当然,在所有这些情况下,我指的是浏览器,因为它们没有自定义的mime/应用程序映射。

在ASP.net MVC中,你可以使用FileContentResult和File方法:

public FileContentResult DownloadManifest() {
    byte[] csvData = getCsvData();
    return File(csvData, "text/csv", "filename.csv");
}

根据RFC 4180, CSV的MIME类型为text/ CSV。

就像这样使用

Response.Clear();
Response.ContentType = "application/CSV";
Response.AddHeader("content-disposition", "attachment; filename=\"" + filename + ".csv\"");
Response.Write(t.ToString());
Response.End();

试试其他的mime类型(从这里:http://filext.com/file-extension/CSV)

文本/逗号分隔值 文本/ csv 应用程序/ csv 应用程序/ excel 应用程序/ vnd.ms-excel 应用程序/ vnd.msexcel

此外,mime类型可能是区分大小写的……