gpt4 book ai didi

c# - CsvHelper:将空字符串写为特殊字符串

转载 作者:行者123 更新时间:2023-11-30 16:41:26 24 4
gpt4 key购买 nike

我正在尝试将 CsvWriter 配置为使用特殊字符串“#NULL#”作为可为 null 的字符串属性。对于读者来说,它可以通过设置 csvReader.Configuration.TypeConverterOptionsCache.GetOptions<string>().NullValues.Add("#NULL#"); 来实现。 - 它将 csv 中的“#NULL#”字段读取为空字符串。

下面是我用于 writer 的代码,但它会忽略添加的 NullValues 并改为输出空字符串(默认行为)。writer还有其他配置参数吗?谢谢。

        public class Entity
{
public string Name { get; set; }
public int Id { get; set; }
}

[Test]
public void csv_write_test()
{
var entities = new[] {new Entity {Id = 1, Name = null}, new Entity {Id=2, Name = "SampleName"} };

var fileName = "C:/Temp/tr/recordings/withNulls/sample-test.csv";
File.Delete(fileName);

using (var textWriter = new StreamWriter(fileName))
{
var csvWriter = new CsvWriter(textWriter);

csvWriter.Configuration.TypeConverterOptionsCache.GetOptions<string>().NullValues.Add("#NULL#");

csvWriter.WriteRecords(entities);
}
}

最佳答案

您可以使用自定义 ITypeConverter 来完成此操作。

void Main()
{
using (var stream = new MemoryStream())
using (var writer = new StreamWriter(stream))
using (var reader = new StreamReader(stream))
using (var csv = new CsvWriter(writer))
{
var records = new List<Test>
{
new Test { Id = 1, Name = "one" },
new Test { Id = 2, Name = null },
};

csv.Configuration.RegisterClassMap<TestMap>();
csv.WriteRecords(records);

writer.Flush();
stream.Position = 0;

reader.ReadToEnd().Dump();
}
}

public class Test
{
public int Id { get; set; }
public string Name { get; set; }
}

public sealed class TestMap : ClassMap<Test>
{
public TestMap()
{
Map(m => m.Id);
Map(m => m.Name).TypeConverter<CustomNullTypeConverter<string>>();
}
}

public class CustomNullTypeConverter<T> : DefaultTypeConverter
{
public override string ConvertToString(object value, IWriterRow row, MemberMapData memberMapData)
{
if (value == null)
{
return "#NULL#";
}

var converter = row.Configuration.TypeConverterCache.GetConverter<T>();
return converter.ConvertToString(value, row, memberMapData);
}
}

如果您希望它使用 NullValues 选项中的第一个值,您需要提交功能请求。

关于c# - CsvHelper:将空字符串写为特殊字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49049123/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com