1、在项目中经常需要把报表下载为csv格式的文件,如何在C#中写csv文件,以下为一个简化的例子,不使用任何控件,旨在说明用法。

前端view

下载结果

2、创建一个MVC项目(Intranet Application),项目结构如下

3、各部分代码:

3.1、定义实体

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace MvcDownLoadCsv.Models
{
public class Person
{
public string Name { get; set; }
public string Code { get; set; }
public string Department { get; set; }
}
}

3.2、定义共用方法,将object数据转换为HtmlString,

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace MvcDownLoadCsv.Extensions
{
public static class DataTypeExtensions
{
public static HtmlString ToHtmlCsv(this object o)
{
if (o == null) return new HtmlString(""); var s = o.ToString(); if (s.Length == ) return new HtmlString(s); s = s.Replace("\"", "\"\"");
HtmlString hs = new HtmlString(s.ToString()); return new HtmlString(string.Concat("\"", s, "\"")); } }
}

3.3、定义公用方法,把Model数据转换为csv格式文件

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Text;
using System.IO;
using System.Text.RegularExpressions; namespace MvcDownLoadCsv
{
public class CsvDownloadResult : ActionResult
{ public CsvDownloadResult(string name, object model)
{ this.name = name;
this.model = model; } private string name;
private object model; public override void ExecuteResult(ControllerContext context)
{ context.HttpContext.Response.Clear();
context.HttpContext.Response.AddHeader("content-disposition", string.Format("attachment; filename=My.{0}.csv", name));
context.HttpContext.Response.ContentEncoding = Encoding.GetEncoding();// Use ANSI encoding
context.HttpContext.Response.ContentType = "application/vnd.ms-excel"; var csv = ""; using (StringWriter sw = new StringWriter())
{ var viewResult = ViewEngines.Engines.FindPartialView(context, name + "Csv");
var viewContext = new ViewContext(context, viewResult.View, new ViewDataDictionary(model), new TempDataDictionary(), sw);
viewResult.View.Render(viewContext, sw); csv = sw.GetStringBuilder().ToString(); csv = Regex.Replace(csv, "\r\n[ ]+\r\n[ ]+", "\r\n");
csv = Regex.Replace(csv, ",\r\n[ ]*", ","); } context.HttpContext.Response.Write(csv); context.HttpContext.Response.End(); } }
}

此例子中context最后为:

\Person Report\"\r\n\r\n\"Name\",\"Person Code\",\"Person Department\",\r\n\"a\" ,\"1\" ,\"Developer\" ,\r\n\"b\" ,\"2\" ,\"Test\" ,\r\n\"c\" ,\"3\" ,\"HR\" ,\r\n"

\r是回车,英文是Carriage return,表示使光标下移一格

\n是换行,英文是New line,表示使光标到行首

\r\n表示回车换行

3.4、定义csv文件格式

@using MvcDownLoadCsv.Extensions
@model List<MvcDownLoadCsv.Models.Person>
"Person Report"
@if (Model.Count == )
{<text>"No Person find."</text>
}
else
{<text>
"Name",
"Person Code",
"Person Department",
</text> foreach (var item in Model)
{ @item.Name.ToHtmlCsv() <text>,</text>
@item.Code.ToHtmlCsv() <text>,</text>
@item.Department.ToHtmlCsv() <text>,</text>
<text></text>
}
}

3.5、后台方法,构造数据,定义响应前端下载的方法

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MvcDownLoadCsv.Models; namespace MvcDownLoadCsv.Controllers
{
public class HomeController : Controller
{
public ActionResult Index()
{
ViewBag.Message = "Welcome to ASP.NET MVC!"; return View(GetPerson());
} public ActionResult About()
{
return View();
} public List<Person> GetPerson()
{
List<Person> lst = new List<Person>()
{
new Person() { Name = "a", Code = "", Department = "Developer" },
new Person() { Name = "b", Code = "", Department = "Test" },
new Person() { Name = "c", Code = "", Department = "HR" }
};
return lst;
} [HttpPost]
public ActionResult DownloadCsv()
{
//Person为定义报表格式的cshtml文件名称, GetPerson()返回的是报表数据
return new CsvDownloadResult("Person", GetPerson());
} } }

3.6、前端页面view

@model List<MvcDownLoadCsv.Models.Person>
@{
ViewBag.Title = "Home Page";
}
<script type="text/javascript"> $(document).ready(function () {
$("#downloadData").click(function (e) {
e.preventDefault();
$("#downloadCriteria")[].submit();
}); $("#copyData").toggle(!!(document.body.createControlRange)).click(function (e) {
e.preventDefault();
try {
var range = document.body.createControlRange();
range.add($("#pis")[]);
range.execCommand("Copy");
alert("Report data was copied to the clipboard.");
}
catch (e) { alert("Failed to copy the report data to the clipboard:\n\n" + e.message); }
});
});
</script> <h2>@ViewBag.Message</h2>
<p>
To learn more about ASP.NET MVC visit <a href="http://asp.net/mvc" title="ASP.NET MVC Website">http://asp.net/mvc</a>.
</p> <div style="height:30px" class="actions">
@if (Model.Count > )
{
<a href="javascript:void(0);" id="downloadData" class="action" title="Download Data to Excel">download</a>
<a href="" id="copyData" class="action" title="Copy Results to Clipboard">copy</a>
<a href="" id="downloadDataForPopup" class="action" title="Download Data to Excel" style="display:none">downloadForPopup</a>
}
</div> <div class="fieldset">
<form action="@Url.Action("DownloadCsv", "Home")" method="post" id="downloadCriteria"> </form>
<table id="projects" class="data">
<tr>
<th>Name</th>
<th>Code</th>
<th>Department</th>
</tr>
@{ foreach (var item in Model)
{
<tr>
<td>@item.Name</td>
<td>@item.Code</td>
<td>@item.Department</td>
</tr>
}
}
</table>
</div>

C#写csv文件的更多相关文章

  1. PLSQL_PLSQL读和写CSV文件方式(案例)

    2012-01-06 Created By BaoXinjin

  2. JavaCSV之写CSV文件

    与JavaCSV读CSV文件相对应,JavaCSV也可以用来写数据到CSV文件中. 1.准备工作 (1)第三方包库下载地址:https://sourceforge.net/projects/javac ...

  3. 【python】写csv文件时遇到的错误

    1.错误 在许多文件中,写入csv文件时都加"wb",w指写入,b指二进制 如: csvwrite=csv.writer(open("output.csv",& ...

  4. spark 写csv文件出现乱码 以及写文件读文件总结

    参考链接:https://blog.csdn.net/qq_56870570/article/details/118492373 result_with_newipad.write.mode(&quo ...

  5. python 写csv文件

    一.只有一列内容: def create_file(self, a, b): # 上传csv 文件 # os.remove('openfile.csv') open_file = open('5000 ...

  6. python笔记5-python2写csv文件中文乱码问题

    前言 python2最大的坑在于中文编码问题,遇到中文报错首先加u,再各种encode.decode. 当list.tuple.dict里面有中文时,打印出来的是Unicode编码,这个是无解的. 对 ...

  7. .NET 创建并写CSV文件

    /// <summary> /// 创建并写日志 /// </summary> /// <param name="SuccessA100">&l ...

  8. python3 写CSV文件多一个空行的解决办法

    Python文档中有提到: open('eggs.csv', newline='') 也就是说,打开文件的时候多指定一个参数.Python文档中也有这样的示例: import csvwith open ...

  9. python写csv文件

    name=['lucy','jacky','eric','man','san'] place=['chongqing','guangzhou','beijing','shanghai','shenzh ...

随机推荐

  1. hdu 2112(字典树+最短路)

    HDU Today Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  2. yii2实现WebService 使用 SoapDiscovery

    结合SoapDiscovery实现简单的WebService服务 1 修改php.ini文件 php_soap.dll extension=php_soap.dll 2 WebService 实现主要 ...

  3. HDU 6235.Permutation (2017中国大学生程序设计竞赛-哈尔滨站-重现赛)

    Permutation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Tot ...

  4. string那些事之replace

    /* 用法一: 用str替换指定字符串从起始位置pos开始 长度为为len的字符串 string &replace(size_t pos, size_t len, const string&a ...

  5. Codeforces 825E - Minimal Labels

    825E - Minimal Labels 题意 给出 m 条有向边,组成有向无环图,输出一个 1 到 n 组成的排列,每个数只能出现一次,表示每个点的标号.如果有边 \((u, v)\) 那么 \( ...

  6. Kali Linux Wine32英文字体不显示问题

     Kali Linux Wine32英文字体不显示问题 Kali Linux提供了Wine32工具.在运行Wine32后,界面可以显示中文,但不能显示英文文字.英文文字均显示为方块.这是由于缺少对应的 ...

  7. RMQ ---- ST(Sparse Table)算法

    [概述]      RMQ(Range Minimum/Maximum Query),即区间最值查询,是指这样一个问题:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返 ...

  8. Windows 8.1中WinRT的变化(一)——新增控件

    这次WinRT的变化还是不小的,就拿新增控件来说,就有如下几种: AppBar 控件 我以前写过一篇文章接受过如何在WinRT程序中快速创建Metro风格图标,现在MS已经把他们标准化了,就不用我们自 ...

  9. .net的远程调用

    .Net远程调用(转自:http://www.cnblogs.com/omilan/articles/3191378.html) 看到了这.net远程调用的讲解,觉得不错,拿来分享!! .Net对于远 ...

  10. 面试题:如何在不使用临时变量temp的情况下交换两个整数的值?

    利用一个小技巧,一个整数a在异或另一个整数b两次以后所得的值还是整数a. 具体的过程我们可以自己找两个整数以二进制的形式自己在纸上画一下他们的异或过程.(异或的运算符号为"^") ...