\ r \ n CSV文件中的字符不会被视为换行符

时间:2016-08-11 06:13:25

标签: javascript c# .net export-to-csv line-breaks

道歉,这肯定是一个傻瓜问题...... 我正在尝试创建一个如下所示的CSV文件:

Header1,Header2,Header3, "Value1","Value2","Value3"

相反,我得到的CSV文件如下所示: Header1,Header2,Header3,\r\n"Value1","Value2","Value3"

如何让我的CRLF字符在输出中实际产生换行符?

我正在做的是对WebMethod进行ajax调用,该WebMethod从存储过程生成数据表。然后将该数据表解析为CSV,如下所示:

if (!createHeaders)//I deal with the headers elsewhere in the code
{
    foreach(DataColumn col in table.Columns){

        result += col.ColumnName + ",";
    };
    result += Environment.NewLine;
}

for (int rowNum = 0; rowNum < table.Rows.Count; rowNum++) 
{
    for (int colNum = 0; colNum < table.Columns.Count; colNum++)
    {
        result += "\"" + (table.Rows[rowNum][colNum]).ToString();
        result += "\",";
    };
    result += Environment.NewLine;
};
return result;
}

然后该字符串被传递回ajax查询的成功函数,在那里它经历了一些转换......

function getExportFile(sType) {
    var alertType = null
    $.ajax({
        type: "POST",      
        url: "./Services/DataLookups.asmx/getExcelExport",
        data: JSON.stringify({ sType: sType }),
        processData: false,
        contentType: "application/json; charset=utf-8",
        dataType: "text",
        success: function (response) {                
            response = replaceAll(response,"\\\"", "\"")
            response = response.replace("{\"d\":\"", "")
            response = response.replace("\"}", "")
            download(sType + ".csv",response)
        }
    });

    function download(filename, text) {
        var element = document.createElement('a');
        element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(text));
        element.setAttribute('download', filename);
        element.style.display = 'none';
        document.body.appendChild(element);
        element.click()
        document.body.removeChild(element);
    }

    function escapeRegExp(str) {
        return str.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, "\\$1");
    }

    function replaceAll(str, find, replace) {
        return str.replace(new RegExp(escapeRegExp(find), 'g'), replace);
    }

在我的调试之前,字符串被传递回javascript,如果我只是输入?response,我得到错误的,一对一的响应。但是,当我输入“共鸣”时,nq会识别换行符,并且所有内容都应该是它应该的样子。

另外,我确信在这里我有错误/愚蠢。指出这些情况也很受欢迎。

2 个答案:

答案 0 :(得分:1)

您的标头应该以{{1​​}}作为MIME类型而不是data:Application/octet-stream,,原因是根据HTTP规范,当内容类型未知时,收件人应将其视为类型application / octet -stream。

由于您已经在使用data:text/plain;charset=utf-8,,这似乎是唯一剩下的问题。

答案 1 :(得分:1)

@ AryKay的答案肯定有帮助,但还有一个问题。 Ajax调用返回的字符串将\r\n转义为文字。跑一个

Response = response.replace (/\\r\\n/g, "\r\n")

在传递给encodeURIComponent之前,它就像一个魅力。