CsvHelper文档-4映射

类映射

有时候你的类成员和csv的header不一定对应,有时候你的csv文件根本就没有header行,你需要特别制定一个成员的index,你不能依靠.net中默认的顺序。在这些情况下,你可以创建一个类映射文件来映射类成员和csv文件字段。

为了创建一个类到csv文件的映射,你需要一个ClassMap,你可以映射任何公共成员(属性或者字段);

public class MyClass
{
public int Id { get; set; }
public string Name { get; set; }
} public sealed class MyClassMap : ClassMap<MyClass>
{
public MyClassMap()
{
Map( m => m.Id );
Map( m => m.Name );
}
}

上面这个例子其实就是把类和文件做个默认对应,也就是说,按照顺序,第一个Id对应的是csv的第一个字段Id,类推。

要使用这个映射文件,你需要在configuration中注册它

var csv = new CsvReader( textReader );
csv.Configuration.RegisterClassMap<MyClassMap>();

Configuration可以做一些设置,后面再说

引用映射

为了映射一个引用类型,你需要按照树结构引用成员就是了,深度没有限制。

public class A
{
public int Id { get; set; }
public B B { get; set; }
} public class B
{
public int Id { get; set; }
public C C { get; set; }
} public class C
{
public int Id { get; set; }
} public sealed class AMap : ClassMap<A>
{
public AMap()
{
Map( m => m.Id ).Name( "A" );
Map( m => m.B.Id ).Name( "B" );
Map( m => m.B.C.Id).Name( "C" );
}
}

自动映射

如果你在没有创建映射字段的情况下进行读写,映射文件会自动的创建并自动的应用。自动映射会在对象成员和文件字段之间按照默认的映射设定创建映射关系。你可以通过configuration来改变一些默认设定。如果有循环引用,自动映射会停止这个结点的深入,继续下一个结点。

你可以在映射文件中直接调用AutoMap方法,如果你只有少数几个需要自己映射的,你可以先用AutoMap来建立初始的映射,然后再手动将特殊的几个映射手动完成。

public class MyClass
{
public int Id { get; set; } public string Name { get; set; } public DateTime CreatedDate { get; set; }
} public sealed class MyClassMap : ClassMap<MyClass>
{
public MyClassMap()
{
AutoMap();
Map( m => m.CreatedDate ).Ignore();
}
}

选项

通过选项可以改变映射行为。

Name

可以指定Header的名称,读取的字段如果有多个名称,甚至可以制定多个名称。所有名称都会被检查一遍来查找对应的字段。写入的时候只会用到第一个字段。

// Single name
Map( m => m.Id ).Name( "id" ); // Multiple possible names
Map( m => m.Id ).Name( "id", "the_id", "Id" );

NameIndex

如果一个列名出现在多个列,可以在映射的时候直接指定这个列的Index(具体是相同Name的Index);

// Example header
id,name,id // Mapping
Map( m => m.Id ).Name( "id" ).Index( 1 );

Index

如果根本就没有header,可以直接指定列的Index,如果有Name,则优先使用Name再考虑Index。写入的时候都可以指定,确保列的位置正确。

Map( m => m.Id ).Index( 0 );

Default

指定一个默认值,如果读取的位置字段是空的话;(相当于替代字符

Map( m => m.Name ).Default( "empty" );

Constant

指定一个值作为读写字段的时候的常量,如此,使用这个值的时候会忽略映射设置。

Map( m => m.Name ).Constant( "never changes" );

Ignore

在读写的时候忽略某个字段;注意:如果一个成员已经被映射到一个引用成员,不管是用类映射文件,还是自动映射,调用这个方法都不会忽略所有已经被映射子成员。

Map( m => m.Name ).Ignore();

TypeConverter

当需要进行类型转换的时候,可以指定ITypeConverter接口;

Map( m => m.Name ).TypeConverter( new MyConverter() );
Map( m => m.Name ).TypeConverter<MyConverter>();

ConvertUsing

可以指定一个转换字段到成员,转换成员到字段的表达式;

// Convert to member
Map( m => m.Aggregate ).ConvertUsing( row => row.Get<int>( "A" ) + row.Get<int>( "B" ) ); // Block
Map( m => m.Aggregate ).ConvertUsing( row =>
{
var a = row.Get<int>( "A" );
var b = row.Get<int>( "B" );
return a + b;
} ); // Convert to field
Map( m => m.Aggregate ).ConvertUsing( m => $"A + B = {m.A + m.B}" ); // Block
Map( m => m.Aggregate ).ConvertUsing( m =>
{
var field = "A + B = ";
field += ( m.A + m.B ).ToString();
return field;
} );

Validate

当读取的时候可以指定一个表达式来验证字段,如果表达式返回false,则抛出ValidationException异常。

Map( m => m.Number ).Validate( field => !string.IsNullOrEmpty( field ) );

// Log error instead of throwing an exception.
Map( m => m.Number ).Validate( field =>
{
var isValid = !string.IsNullOrEmpty( field );
if( !isValid )
{
logger.AppendLine( $"Field '{field}' is not valid!" );
} return true;
} );```

CsvHelper文档-4映射的更多相关文章

  1. CsvHelper文档-6类型转换

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

  2. CsvHelper文档-5配置

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

  3. CsvHelper文档-2读

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

  4. CsvHelper文档-3写

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

  5. CsvHelper文档-1前言

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

  6. Elasticsearch6.4.3文档的映射

    已经把ElasticSearch的核心概念和关系数据库做了一个对比,索引(index)相当于数据库,类型(type)相当于数据表,映射(Mapping)相当于数据表的表结构.ElasticSearch ...

  7. ES 父子文档查询

    父子文档的特点 1. 父/子文档是完全独立的. 2. 父文档更新不会影响子文档. 3. 子文档更新不会影响父文档或者其它子文档. 父子文档的映射与索引 1. 父子关系 type 的建立必须在索引新建或 ...

  8. elasticsearch 路由文档到分片

    路由文档到分片 当你索引一个文档,它被存储在单独一个主分片上.Elasticsearch是如何知道文档属于哪个分片的呢?当你创建一个新文档,它是如何知道是应该存储在分片1还是分片2上的呢? 进程不能是 ...

  9. MongoDB - 文档之间的关系 + _sort和投影

    1. 文档对象之间的关系 一对一 (one TO one) - 例如: 夫妻 (一个丈夫 对应 一个妻子) - 在MongoDB中, 可以通过内嵌文档的形式来体现出一对一的关系 演示: 首先在 my_ ...

随机推荐

  1. HDU 1711 Number Sequence (KMP简单题)

    Number Sequence Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. fdfs上传图片成功在浏览器中访问不到404 Not Found

    1.检查自己nginx配置文件,看是否有   user root这行 . 在nginx.conf文件里加一条:user root; 2.检查自己配置文件: storage.conf中的文件路径是否正确 ...

  3. Annotation原理

    为什么使用注解: 1.通过注解,可保存源数据在Java源代码中:并且注解不同于注释,注解享有编译期的类型检查保护. 2.可在描述符性质的类或接口中抽取重复性的工作,通过注解来简化与自动化这些工作. 注 ...

  4. Oracle中函数的使用

      1.decode () 例子:它的写法如下decode('a','b','c','d'),其中a,b,c,d可以是其他函数也可以是数值,依据我们自己的情况来使用,它的含义是如果a=b,那么结果显示 ...

  5. App跳转系统设置界面

    NSString * urlString = @"App-Prefs:root=WIFI"; if ([[UIApplication sharedApplication] canO ...

  6. maven添加本地jar

    maven有时需要添加了一些本地jar,记录下流程 1.在项目名下创建一个文件夹,起名为lib吧,放要的jar放进去 2.然后打开jar在的路径,打开命令窗口,执行 mvn install:insta ...

  7. Redis事件

    Redis事件 Redis的ae(Redis用的事件模型库) ae.c Redis服务器是一个事件驱动程序,服务器需要处理以下两类事件: 文件事件(file event):Redis服务器通过套接字与 ...

  8. PHP结合zyupload多功能图片上传实例

    PHP结合zyupload多功能图片上传实例,支持拖拽和裁剪.可以自定义高度和宽度,类型,远程上传地址等. zyupload上传基本配置 $("#zyupload").zyUplo ...

  9. php计算上个月是几月份

    PHP计算上个月的时间, $date = date("Y-m-d"); $arr = explode('-',$date); foreach ($arr as $key=>$ ...

  10. BurpSuite系列(一)----Proxy模块(代理模块)

    一.简介 Proxy代理模块作为BurpSuite的核心功能,拦截HTTP/S的代理服务器,作为一个在浏览器和目标应用程序之间的中间人,允许你拦截,查看,修改在两个方向上的原始数据流. Burp 代理 ...