4

我已经使用System.Text.Encoding.ASCII.GetString(ms.ToArray));我的内存流验证了预期的数据。

但是,使用 LinqToCSV nuget 库不会生成我的 csv 文件。我没有抛出任何错误或异常。当我被提示打开文件时,我只是得到一个空文件。

这是我的操作方法

 public FileStreamResult  Export(){

        var results = _service.GetProperties().Take(3);
        System.IO.MemoryStream ms = new System.IO.MemoryStream();
        System.IO.TextWriter  txt = new System.IO.StreamWriter(ms); 


        CsvFileDescription inputFileDescription = new CsvFileDescription{
            SeparatorChar =',',
            FirstLineHasColumnNames = true
        }
            ; 

        CsvContext csv = new CsvContext();

        csv.Write(results,txt,inputFileDescription);



        return File(ms , "application/x-excel"); 
    }

我发现这很有趣,如果我将返回类型更改为 contentResult,并将返回方法更改为 Content() 并传递它,System.Text.Encoding.ASCII.GetString(ms.ToArray));我会得到一个显示我的数据的浏览器窗口。

4

2 回答 2

5

确保将流位置重置为 0。还要确保StreamWriter在此之前刷新。

于 2013-03-15T17:02:32.113 回答
5

调用 Web API 方法从 JavaScript 返回 CVS 文件。

public HttpResponseMessage Bidreport([FromBody]int formData).....

填写您的IEnumerable<YourObject>query= from LINQ query .... 这是如何返回它:

 using (var ms = new MemoryStream())
            {
                using (TextWriter txt = new StreamWriter(ms))
                {
                    var cc = new CsvContext();
                    cc.Write(query, txt, outputFileDescription);
                    txt.Flush();
                    ms.Position = 0;
                    var fileData = Encoding.ASCII.GetString(ms.ToArray());
                    var result = new HttpResponseMessage(HttpStatusCode.OK) {Content = new StringContent(fileData)};
                    result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/x-excel");
                    return result;
                }
            }         
于 2014-02-12T20:09:36.083 回答