在csv导出中跳过逗号(,)

时间:2018-02-20 11:13:10

标签: javascript angularjs csv export-to-csv

所以,我已经找到了其他几个有相关答案的SO问题,并尝试了大部分问题,但似乎没有什么对我有用。可能是因为我的案子比以前的案件复杂得多。

这是我的csv文件,它有几个特殊字符[,' "]

ID,Name,Executable,Host,Timeout,Tags,Visible,
65,one test,SomePROXY=http://10.10.10.10 /abc/cde/efg/some.py -u tom -g 'some-abc-test' --passparams "one,two",example.com,1800,nothing,true,

我的预期excel格式为:

ID: 65
Name: one test
Executable: SomePROXY=http://10.10.10.10 /abc/cde/efg/some.py -u tom -g 'some-abc-test' --passparams "one,two"
Host: example.com
Timeout: 1800
Tags: nothing
Visible: true

但由于可执行字段中的逗号,"两个"进入新专栏。 我试着引用"""""" (正如其他答案中所建议的那样)但这看起来并不奏效。

任何人都可以在这里帮助我。

这是我的代码,我在这里尝试使用(对于ag-grid表)

    $scope.export_data_csv = function(){
        var LINE_SEPARATOR = '\r\n';
        var COLUMN_SEPARATOR = ',';
        var fileName = 'export.csv';

        let csvString = '';
        let columnsToExport = $scope.ag_grid_options.api.columnController.getAllDisplayedColumns();

        // adding column headers.
        columnsToExport.map((column) => {
          csvString+= column.colDef.headerName;
          csvString+= COLUMN_SEPARATOR;
        });
        csvString+= LINE_SEPARATOR;

        // adding content of data currently loaded in the grid.
        $scope.ag_grid_options.api.forEachNode( function(node) {
          node.columnController.allDisplayedColumns.map((column) => {
            let cellContent = node.valueService.getValue(column, node);
            if(typeof(cellContent) == 'object'){
                cellContent = cellContent.join("; ")
            }
            csvString+= (cellContent != null) ? cellContent : "";
            csvString+= COLUMN_SEPARATOR;
          });
          csvString+= LINE_SEPARATOR;
        });

        // for Excel, we need \ufeff at the start
        var blobObj = new Blob(["\ufeff", csvString], {
            type: "text/csv;charset=utf-8;"
        });
        // Internet Explorer
        if (window.navigator.msSaveOrOpenBlob) {
            window.navigator.msSaveOrOpenBlob(blobObj, fileName);
        }
        else {
            // Chrome
            var downloadLink = document.createElement("a");
            downloadLink.href = window.URL.createObjectURL(blobObj);
            downloadLink.download = fileName;
            document.body.appendChild(downloadLink);
            downloadLink.click();
            document.body.removeChild(downloadLink);
        }
    }

1 个答案:

答案 0 :(得分:1)

你必须将'Excecutable'的整个值声明为字符串,并使用额外的双引号转义里面的双引号。

ID,Name,Executable,Host,Timeout,Tags,Visible,
65,one test,"SomePROXY=http://10.10.10.10 /abc/cde/efg/some.py -u tom -g 'some-abc-test' --passparams ""one,two""",example.com,1800,nothing,true,