写入CSV然后保存或编辑

时间:2018-02-28 13:56:25

标签: c# csv

我有问题。我在运行时创建一个CSV,然后让用户保存或打开它,但它对我没有任何作用,我做错了什么?有人能帮助我吗?

public void WriteToCSV(List<mifid2_vpc_monitored_detail_view> list, string filename)
    {
        string attachment = "attachment; filename=" + filename;

        HttpContext.Current.Response.Clear();
        HttpContext.Current.Response.ClearHeaders();
        HttpContext.Current.Response.ClearContent();
        HttpContext.Current.Response.AddHeader("content-disposition", attachment);
        HttpContext.Current.Response.ContentType = "text/csv";
        HttpContext.Current.Response.AddHeader("Pragma", "public");
        HttpContext.Current.Response.ContentEncoding = Encoding.UTF8;


        WriteHeader();
        StringBuilder csv = new StringBuilder();

        string _uti, _counterparty;
        DateTime _maturity, _date;
        decimal _volume;

        var newLine = "";

        for (int i = 0; i < list.Count; i++)
        {
            if (list[i].uti_cd == null) _uti = "-"; else _uti = list[i].uti_cd;
            if (list[i].namecounterparty == null) _counterparty = "-"; else _counterparty = list[i].namecounterparty;
            if (list[i].maturity == null) _maturity = DateTime.MinValue.Date; else _maturity = list[i].maturity;
            if (list[i].contract_volume == 0) _volume = 0; else _volume = list[i].contract_volume;
            if (list[i].evaluation_date == null) _date = DateTime.MinValue.Date; else _date = list[i].evaluation_date;

            newLine = string.Format("{0},{1},{2},{3},{4}", _uti, _counterparty, _maturity, _volume, _date);
            csv.AppendLine(newLine);
        }

        HttpContext.Current.Response.Write(csv.ToString());
        HttpContext.Current.Response.End();
    }

    private void WriteHeader()
    {
        string columnNames = "UTI code, Counterparty, Maturity, Volume, Evaluation Date";
        HttpContext.Current.Response.Write(columnNames);
        HttpContext.Current.Response.Write(Environment.NewLine);
    }

3 个答案:

答案 0 :(得分:0)

代码对我来说很好。但浏览器没有扩展名下载文件。

filename是否包含文件扩展名?

如果没有,试试这个

string attachment = "attachment; filename=" + filename + ".csv";

答案 1 :(得分:0)

我仍然不明白问题出在哪里,我尝试了不同的解决方案,然后我在网上发现了一个通过演示工作的例子,但是一旦我实现它,它就不起作用,它可能就是我使用sharepoint 2013以及引用导出的按钮是否在webpart中?

代码:

HttpResponse Response = HttpContext.Current.Response;

string csv = string.Empty;
csv += "UTI code, Counterparty, Maturity, Volume, Evaluation Date";
csv += "\r\n";

string _uti, _counterparty;
DateTime _maturity, _date;
decimal _volume;

for (int i = 0; i < list.Count; i++)
        {
            if (list[i].uti_cd == null) _uti = "-"; else _uti = list[i].uti_cd;
            if (list[i].namecounterparty == null) _counterparty = "-"; else _counterparty = list[i].namecounterparty;
            if (list[i].maturity == null) _maturity = DateTime.MinValue.Date; else _maturity = list[i].maturity;
            if (list[i].contract_volume == 0) _volume = 0; else _volume = list[i].contract_volume;
            if (list[i].evaluation_date == null) _date = DateTime.MinValue.Date; else _date = list[i].evaluation_date;
            csv += _uti + ",";
            csv += _counterparty + ",";
            csv += _maturity + ",";
            csv += _volume + ",";
            csv += _date;
            csv += "\r\n";
        }

        Response.Clear();
        Response.Buffer = true;
        Response.AddHeader("content-disposition", "attachment;filename=SqlExport.csv");
        Response.Charset = "";
        Response.ContentType = "application/text";
        Response.Output.Write(csv);
        Response.Flush();
        Response.End();

答案 2 :(得分:-2)

这应该有所帮助:

public void WriteToCSV(List<mifid2_vpc_monitored_detail_view> list, string filename)
    {
    string attachment = "attachment; filename=" + filename;

    HttpContext.Current.Response.Clear();
    HttpContext.Current.Response.ClearHeaders();
    HttpContext.Current.Response.ClearContent();
    HttpContext.Current.Response.AddHeader("content-disposition", attachment);
    HttpContext.Current.Response.ContentType = "text/csv";
    HttpContext.Current.Response.AddHeader("Pragma", "public");
    HttpContext.Current.Response.ContentEncoding = Encoding.UTF8;


    WriteHeader();
    StringBuilder csv = new StringBuilder();

    string _uti, _counterparty;
    DateTime _maturity, _date;
    decimal _volume;

    var newLine = "";

    for (int i = 0; i < list.Count; i++)
    {
        if (list[i].uti_cd == null) _uti = "-"; else _uti = list[i].uti_cd;
        if (list[i].namecounterparty == null) _counterparty = "-"; else _counterparty = list[i].namecounterparty;
        if (list[i].maturity == null) _maturity = DateTime.MinValue.Date; else _maturity = list[i].maturity;
        if (list[i].contract_volume == 0) _volume = 0; else _volume = list[i].contract_volume;
        if (list[i].evaluation_date == null) _date = DateTime.MinValue.Date; else _date = list[i].evaluation_date;

        newLine = string.Format("{0},{1},{2},{3},{4}", _uti, _counterparty, _maturity, _volume, _date);
        csv.AppendLine(newLine);
    }


    MemoryStream mstream = new MemoryStream();
    StreamWriter sw = new StreamWriter(mstream);
    sw.Write(csv);
    sw.Flush();
    sw.Close();
    byte[] byteArray = mstream.ToArray();
    mstream.Flush();
    mstream.Close();
    HttpContext.Current.Response.BinaryWrite(byteArray);
    HttpContext.Current.Response.End();
}