CsvHelper:将空字符串写为特殊字符串

CsvHelper: writing null strings as special string

我正在尝试将 CsvWriter 配置为使用特殊字符串“#NULL#”作为可为 null 的字符串属性。对于 reader 它有效,通过设置 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 选项中的第一个值,您需要提交功能请求。