如何解决CSV Helper 在分隔符后将字符串字段“名称”包装成双引号?
我的文件中的 CSV 结果有一些问题, 我已经在代码中编写了下一个配置(我正在使用 CSVHelper 库)
const epochNow = new Date(
+moment("20210316200005",'YYYYMMDDHHmmss')
).getTime();
console.log('epoch ',epochNow,' ',currMoment);
客户需要在“姓名”文本=>“姓名”之间添加空格。 但是,库将字符串包装到双引号中的 'Name' 中,对我来说,这是错误的行为。 我怎样才能制作--Surname; Name-- 而不是 --Surname;" Name"--?
我在 CsvWriter 中找不到任何特定的配置来修复它
如果需要,我的保存逻辑
public class ReportModelMap : ClassMap<ReportModel>
{
public ReportModelMap()
{
Map(x => x.Name).Index(9).Name(" Name");
}
}
解决方法
@Panagiotis Kanavos 是正确的。您可以使用 ShouldQuote
来覆盖该标题的引用行为。
void Main()
{
var ratingModels = new List<ReportModel>
{
new ReportModel { Id = 1,Surname = "Surname",Name = " Name" }
};
//using (var writer = new StreamWriter(path))
using (var csvWriter = new CsvWriter(Console.Out,CultureInfo.InvariantCulture))
{
csvWriter.Configuration.RegisterClassMap<ReportModelMap>();
csvWriter.Configuration.Delimiter = ";";
csvWriter.Configuration.ShouldQuote = (field,context) =>
{
if (!context.HasHeaderBeenWritten && field == " Name")
{
return false;
}
else
{
return ConfigurationFunctions.ShouldQuote(field,context);
}
};
csvWriter.WriteRecords(ratingModels);
}
}
// You can define other methods,fields,classes and namespaces here
public class ReportModelMap : ClassMap<ReportModel>
{
public ReportModelMap()
{
Map(x => x.Id).Index(0);
Map(x => x.Surname).Index(1);
Map(x => x.Name).Index(2).Name(" Name");
}
}
public class ReportModel
{
public int Id { get; set; }
public string Surname { get; set; }
public string Name { get; set; }
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。