我有一个带有字段标题的CSV文件,其中一些包含两个或三个用空格分隔的单词:
您可以在上图中看到包含空格的字段标题:
"时间","流程名称"和"图像路径"。
当我尝试通过调用reader.GetRecords<DataRecord>();
来读取CSV时(其中DataRecord
是我定义的类),我收到错误:
字段&#39; TimeOfDay&#39; CSV文件中不存在。&#34; *
这是因为我的DataRecord
课程不能包含带空格的成员。
如何使用CsvHelper解析CSV文件?
答案 0 :(得分:24)
基于CsvHelper Documentation,有几种方法可以达到我们想要的效果。
<强> 1。忽略标题中的空格 (我认为应该可以轻松解决您的问题)
在CsvHelper 3或更高版本中,使用PrepareHeaderForMatch
(记录在http://joshclose.github.io/CsvHelper/configuration#headers)从标题中删除空格:
csv.Configuration.PrepareHeaderForMatch =
header => Regex.Replace(header, @"\s", string.Empty)
在CsvHelper 2中,设置IgnoreHeaderWhiteSpace
标志,告诉读者在按名称将列与属性匹配时忽略标题中的空格。
reader.Configuration.IgnoreHeaderWhiteSpace = true;
<强> 2。手动阅读
我们可以手动阅读每个字段,如:
var reader = new CsvReader(sr);
do
{
reader.Read();
var record=new DataRecord();
record.TimeOfDay=reader.GetField<string>("Time of Day");
record.ProcessName=reader.GetField<string>("Process Name");
record.PID=reader.GetField<string>("PID");
record.Operation=reader.GetField<string>("Operation");
record.Path=reader.GetField<string>("Path");
record.Result=reader.GetField<string>("Result");
record.Detail=reader.GetField<string>("Detail");
record.ImagePath=reader.GetField<string>("Image Path");
} while (!reader.IsRecordEmpty());
第3。类映射:
我们可以使用name class mapping
手动映射我们班级的属性和CSV文件中的标题,如下所示:
public sealed class DataRecordMap:CsvClassMap<DataRecord>
{
public DataRecordMap()
{
Map( m => m.TimeOfDay).Name("Time Of Day");
Map( m => m.ProcessName).Name("Process Name");
Map( m => m.PID).Name("PID");
Map( m => m.Operation).Name("Operation");
Map( m => m.Path).Name("Path");
Map( m => m.Result).Name("Result");
Map( m => m.Detail).Name("Detail");
Map( m => m.ImagePath).Name("Image Path");
}
}
然后我们应该使用以下方式注册:
reader.Configuration.RegisterClassMap<DataRecordMap>();
答案 1 :(得分:1)
该库现在支持attributes。您可能要使用Name属性。
public class DataRecord
{
[Name("Time of Day")]
public string TimeOfDay { get; set; }
[Name("Process Name")]
public string ProcessName { get; set; }
public string PID { get; set; }
public string Operation { get; set; }
public string Path { get; set; }
public string Result { get; set; }
public string Detail { get; set; }
[Name("Image Path")]
public string ImagePath { get; set; }
public static IEnumerable<DataRecord> ParseDataRecords(Stream file)
{
using (var sr = new StreamReader(file))
using (var csv = new CsvReader(sr))
{
foreach (var record in csv.GetRecords<DataRecord>())
{
yield return record;
}
}
}
}
答案 2 :(得分:0)
答案 3 :(得分:0)
在为此苦苦挣扎之后,这对我有用。我正在使用版本 3。
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
PrepareHeaderForMatch = args => args.Header.Replace(" ","")
};
using (var reader = new StreamReader("my_csv_file.csv"))
using (var csv = new CsvReader(reader, config))
我相信我正在创建一个配置 (config) 来附加或修改 InvariantCulture 并使用 C# 中的 Replace 函数来删除空格。到目前为止,它对我有用。