CsvHelper文档-3写

不用做任何设置,默认的情况下,csvhelper就可以很好的工作了。如果你的类的属性名称和csv的header名称匹配,那么可以按照下面的例子写入:

  1. var records = new List<MyClass> { ... };
  2. var csv = new CsvWriter( textWriter );
  3. csv.WriteRecords( records );
  4. //对应的Stream必须flush一下,否则不会写入

注入警告

当用外部程序打开一个csv文件的时候,字段的标识可能会包含可执行公式会导致脆弱性。因此,如果一个字段是以 = @ + - 开始,字段将会被设置一个\t,如果字段被引用,那么\t将会以”结束(这句话的意思是,在电子表格软件中=开始的会被解释为公式

  1. =one -> \t=one
  2. "=one" -> "\t=one"

你可以在设置中关闭这个功能:

  1. csv.Configuration.SanitizeForInjection = false;

写入所有记录

最常用的是WriteRecords方法,你可以传递给他一个IEnumerable类型的记录,然后它会写入所有的记录;

WriteRecords

  1. var records = new List<MyClass>
  2. {
  3. new MyClass { Id = 1, Name = "one" },
  4. new MyClass { Id = 2, Name = "two" },
  5. };
  6. csv.WriteRecords( records );
  7. // Dynamic
  8. var records = new List<dynamic>();
  9. dynamic record = new ExpandoObject();
  10. record.Id = 1;
  11. record.Name = "one";
  12. records.Add( record );
  13. csv.WriteRecords( records );
  14. // Anonymous
  15. var records = new List<object>
  16. {
  17. new { Id = 1, Name = "one" },
  18. new { Id = 2, Name = "two" },
  19. };
  20. csv.WriteRecords( records );
  21. //这里必须对csv进行关闭或者dispose,csv会自动关闭textwriter,从而将缓冲区的数据真实写入文件
  22. //要么就得调用对writer的flush处理

写入一个单独的记录

有时候你会想要一个一个写入每个记录,每当结束几行的写入的时候,不要忘记调用NextRecord来flush数据和写入行结尾。

WriteHeader

写入Header记录,你可以在任何行使用这个方法,可以写入多个Header.

  1. csv.WriteHeader<MyClass>();
  2. csv.WriteHeader( Type type );
  3. csv.NextRecord();

WriteRecord

写入记录

  1. var record = new MyClass { Id = 1, Name = "one" };
  2. csv.WriteRecord( record );
  3. csv.NextRecord();
  4. // Dynamic
  5. dynamic record = new ExpandoObject();
  6. record.Id = 1;
  7. record.Name = "one";
  8. csv.WriteRecord( record );
  9. csv.NextRecord();
  10. // Anonymous
  11. var record = new { Id = 1, Name = "one" };
  12. csv.WriteRecord( record );
  13. csv.NextRecord();

写入字段

可以单独写入每个字段

WriteField

写入一个字段的类型,你可以使用你自己的ITypeConverter来处理类型到String的转换,如果现有的converter没有合适的类型。

  1. // Write a string
  2. csv.WriteField( "field" );
  3. // Write a string passing in a value indicating
  4. // if the field should be quoted. This will ignore
  5. // any configuration and only quote based on the
  6. // shouldQuote parameter passed in.
  7. csv.WriteField( "field", true );
  8. // Write any type
  9. csv.WriteField( 1 );
  10. // Write any type and use the given type converter
  11. // to convert the type to a string.
  12. csv.WriteField( value, myTypeConverter );
  13. // Write any type and use the given type converter
  14. // to convert the type to a string.
  15. csv.WriteField<MyTypeConverter>( value );
  16. // Write a field that has already been converted
  17. // by a type converter. If the field is null, it
  18. // won't get written.
  19. csv.WriteConvertedField( "field" );
  20. // Don't forget to forget to end the row.
  21. csv.NextRecord();

WriteComment

这个方法将会使用Configuration.Comment中的Comment字符来写入文本。

结束一行

当你结束写入一行的时候,你需要flush一下字段,重新开始一个新行,Flushing和开始一个新行是分开的,所以你可以在没有开始新行的时候就Flush,调用NextRecord就会自动为你Flush。

Flush

这个方法会序列化字段到TextReaderTextWriter。

  1. csv.Flush();

FlushAsync

异步序列化字段到TextReaderTextWriter,如果TextReaderTextWriter连接的是网络或者其他慢速地写入,异步执行会是个好主意。

  1. csv.FlushAsync();

NextRecord

结束当前记录开始新的记录,调用Flush,然后写入新行。

  1. csv.NextRecord();

NextRecordAsync

异步结束当前记录开始新的记录,调用FlushAsync,然后异步写入新行。

  1. csv.NextRecordAsync();

写入上下文

和之前读的部分相同,所以略。

CsvHelper文档-3写的更多相关文章

  1. CsvHelper文档-1前言

    CsvHelper文档-1前言 英文文档链接地址:CsvHelper Document 开源项目地址:CsvHelper 翻译于2018-1-5,原本可能会随时更新: 每一段代码都是经过我实际测试的, ...

  2. CsvHelper文档-6类型转换

    CsvHelper文档-6类型转换 CsvHelper使用类型转换器来转换string到对象,或者对象到string: ITypeConverter 类型转换器的结构,必须实现: public int ...

  3. CsvHelper文档-5配置

    CsvHelper文档-5配置 CsvHelper库被设计成快速且简单易用,但是有时候默认的是设置不符合要求,需要你自己改变一些东西.所以csvHelper内置了很多自定义设置选项来改变读写行为.特别 ...

  4. CsvHelper文档-4映射

    CsvHelper文档-4映射 类映射 有时候你的类成员和csv的header不一定对应,有时候你的csv文件根本就没有header行,你需要特别制定一个成员的index,你不能依靠.net中默认的顺 ...

  5. CsvHelper文档-2读

    CsvHelper文档-2读 这个库默认不需要做任何设置就可以很容易的使用它.如果你的类属性名称直接匹配csv的标题名称,那么可以按照下面的实例来用: (以下所有的代码都需要引用using csvhe ...

  6. app开发需求文档怎么写

    我们在开发app前都会做需求分析,这个app开发需求文档怎么写呢?一般可以从这几点入手:确定APP方案的目标,APP方案的受众分析,APP开发方案功能设计,APP的操作系统说明方案,APP是是否是原生 ...

  7. document.write 向文档中写内容,包括文本、脚本、元素之类的,但是它在什么时候执行不会覆盖当前页面内容尼?

    当你打开一个页面,浏览器会 调用 document.open() 打开文档 document.write(...) 将下载到的网页内容写入文档 所有内容写完了,就调用 document.close() ...

  8. 用C++向一个txt文档中写数据

    bool CMaked::WriteFileMake(CString filePath, const char *isChange) { ofstream file; //filePath为该txt文 ...

  9. PRD文档怎么写

    昨天学习PMP的相关文档,正好看到里面讲的PRD文档是怎么写的 就把一些学习过程,思维方式,还有用到的工具给记录下来 方便自己以后需要的时候,再去查阅,再读这个教程的时候,我顺便用脑图画了一下 脑图工 ...

随机推荐

  1. Jenkins+Ant+Jmeter接口自动化集成测试实例

    Jenkins+Ant+Jmeter接口自动化集成测试实例 一.Jenkins安装配置 1.安装配置JDK1.6+环境变量: 2.下载jenkins.war,放入C:\jenkins目录下,目录位置随 ...

  2. import 本质

    一. 模块:用来从逻辑上来组织python代码(变量,函数,类,逻辑,实现一个功能),本质就是,py结尾的python文件 1.1 导入方法: import module import module1 ...

  3. Oracle 统计信息

    Oracle数据库中的统计信息是这样一组数据:它存储在数据字典中,且从多个维度描述了Oracle数据库里对象的详细信息. CBO会利用这些统计信息来计算目标SQL各种可能的,不同的执行路径的成本,从中 ...

  4. swiper在vue中正确的使用方法

    1.安装swiper,执行npm install vue-awesome-swiper --save命令 2.在main.js中添加下面三行 import 'swiper/dist/css/swipe ...

  5. python-类(1)

    ·类(Class) 笔记: Python是一种面向对象(Object Oriented)的编程语言,类(Class)是Python的核心概念.在Python中,不管是列表.字符串.函数和类都是对象. ...

  6. mysql 日志log

    my.ini log-error=D:/phpStudy/PHPTutorial/MySQL/log/error.loglog=D:/phpStudy/PHPTutorial/MySQL/log/my ...

  7. 中国大学MOOC-JAVA学习(浙大翁恺)—— 时间换算

    import java.util.Scanner; public class Main { public static void main(String[] args) { // TODO Auto- ...

  8. C基础 之 list 库奥义

    前言 - 关于 list 思考 list 是最基础的数据结构也是数据结构的基础. 高级 C 代码纽带也是 list. 扯一点, 当你走进了 C 的殿堂, 那么你和 list 增删改查那就是一辈子丫 ~ ...

  9. openssl windows 下 编译 bat

    ++++全部++++++++ @echo offrem set sslpath=C:\0openssl\rem echo %sslpath% set X86_lib=C:\0openssl\32\li ...

  10. python学习笔记(二):基础知识点

    python基本元素 7 // 2 3 7 % 3 1 # 取商以及余数 divmod(7,3) (2, 1) 1j*1j (-1+0j) 10/3 3.3333333333333335 '3,''1 ...