2

我是LinqToCsv,本教程将我的数据转换为可下载的 csv 文件。

我做了什么 :

我创建了一个如下所示的操作:

public FileResult GetReportCsvData(MyFilterModel model)
{
    var data = _myService.GetMyData(model);

    var fileName = String.Format("{0}_{1}_{2:yyyy_MMM_d}", Helpers.GetLoggedInUserName(), "Ad-Reports", DateTime.Today) + ".csv";
    var outputFileDescription = new CsvFileDescription { SeparatorChar = ',', FirstLineHasColumnNames = true };
    
    var cc = new CsvContext();
    cc.Write(data, "c:/" + fileName, outputFileDescription);

    return File("c:/" + fileName, System.Net.Mime.MediaTypeNames.Application.Octet, fileName);
}

并使用以下 jquery 我得到我的 csv 文件:

exportCsv: function () {
    var data = this.getFilters();
    var url = '/MyController/GetReportCsvData';
    var form = document.createElement('form');
    form.action = url;
    form.method = 'POST';
    form.style.display = 'none';        
    for (i in data) {
        if (data[i] != "") {
            var inputElement = document.createElement('textarea');
            inputElement.name = i;
            inputElement.value = data[i];
            form.appendChild(inputElement);
        }
    }
    document.body.appendChild(form);
    form.submit();
}

这有效,我得到了带有下载提示的 csv 文件。

我想要什么

在这里,我必须使用当前代码将文件保存在我的服务器上(C:/filename),然后返回它的 File 对象。

我不想将它保存在我的服务器上。

为了实现这一目标,我必须做出哪些改变?

4

1 回答 1

-1

在您写入磁盘的“cc.Write”上,outputFileDescription 已经是一个 TextStream。因此,不要先将其保存到磁盘,然后使用“文件”从磁盘读取它,只需返回 TextStream

于 2014-02-17T07:25:34.833 回答