2

我有一个记录带有时间戳的值的文件。我必须在特定时间后读取某个值。

例如

文件有

2013-03-03 19:08:22    car   2001 Ford
2013-03-03 19:08:27    Truck 2012 Chevy
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   Jeep
2013-03-03 19:08:52    car 2007   Suburban

我想读取雪佛兰第一个实例的时间,而不是增加 40 秒,然后读取在那之后出现的任何福特。

So based upon the above log
First Chevy is at   19:08:27  
Add 40 seconds      19:09:07
Now Read first Ford that shows up after 19:09:07  in this case that would be one at 19:08:55

我是正则表达式的新手,不确定如何编写它。谢谢

4

1 回答 1

1

首先,我真的不建议您为此使用正则表达式,但您可以使用以下方法:

var data =  @"2013-03-03 19:08:22    car   2001 Ford
2013-03-03 19:08:27    Truck 2012 Chevy
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   Jeep
2013-03-03 19:08:52    car 2007   Suburban";

string regex =
    @"(\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})[^\n\r]+?Chevy.+?(\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})[^\n\r]+?Ford";
var m = Regex.Match(data, regex, RegexOptions.Singleline);

Console.WriteLine("Chevy date: {0}", DateTime.Parse(m.Groups[1].Value));
Console.WriteLine("Ford date: {0}", DateTime.Parse(m.Groups[2].Value));

上面的代码将打印:

Chevy date: 2013-03-03 19:08:27
Ford date: 2013-03-03 19:08:55

您所要做的就是增加 40 秒。您可以AddSeconds(..)使用DateTime.

编辑:上述正则表达式解释:

  • (\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})匹配一些日期时间
  • [^\n\r]+?Chevy尝试在同一行匹配“Chevy”
  • .+?匹配一大段文字...
  • (\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})直到它再次与某个 DateTime 匹配...
  • [^\n\r]+?Ford...在同一行中有“福特”

编辑:这是另一种不需要使用正则表达式的方法:

using (var reader = new StreamReader(@"C:\file-here.txt")) {
    bool chevyFound = false;
    while (!reader.EndOfStream) {
        var line = reader.ReadLine().Trim();

        if (chevyFound && line.EndsWith("Ford")) {
            var fordDate = DateTime.Parse(line.Substring(0, 19));
            Console.WriteLine("Ford Date: {0}", fordDate);
            break;
        }

        if (line.EndsWith("Chevy")) {
            var chevyDate = DateTime.Parse(line.Substring(0, 19));
            Console.WriteLine("Chevy Date: {0}", chevyDate);
            chevyFound = true;
        }
    }
}

也许当有人告诉您应该使用正则表达式时,他/她的意思是在解析 DateTimes 时(而不是 do Substring(0,19))。在这种情况下,您可以将其替换为:

var chevyDate = DateTime.Parse(Regex.Match(line, "^\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2}").Value)
于 2013-03-06T06:29:25.597 回答