我有一个包含多行的文本文件,每行都有时间戳。我想在特定日期拆分它,而不是运行一个常规的Regex.Matches。
所以我有一个名为
的DateTime变量var date;
While(!reader.EndOfStream)
{
//need to split the document at certain date maybe Regex.Split and save it as newData
var matches=Regex.Matches(File.ReadAllText(newData), someWord);
}
我不知道如何使用正则表达式或其他方式在特定点分割文档。我怎么能分开呢?
Portion of datafile is
2013-03-03 19:08:27 Truck 2012 Toyota
2013-03-03 19:08:44 car 2008 Honda
2013-03-03 19:08:55 car 2011 Ford
2013-03-03 19:09:21 car 2005 Nissan
2013-03-03 19:08:29 car 2003 Cadillac
2013-03-03 19:08:32 car 2009 Ford
2013-03-03 19:08:52 car 2007 Suburban";
答案 0 :(得分:2)
您可以根据文本文件中的数据创建匿名对象列表,然后根据您的目标查询列表
示例:
// create anonymous objects
var myData = File.ReadAllLines("c:\\test.txt")
.Select(line => line.Split(new char[]{' '}, StringSplitOptions.RemoveEmptyEntries))
.Select(splits => new
{
Date = DateTime.Parse(splits[0] + " " + splits[1]),
Make = splits[2].Trim(),
Year = int.Parse(splits[3].Trim()),
Model = splits[4].Trim()
});
// find all "Ford" at my date
var results = myData.Select(x => x.Date == myDate && x.Model == "Ford");
注意:您可能希望为匿名对象创建(int.TryParse,DateTime.TryParse)添加一些错误处理,因为您的文本文件可能不一致。