3 回答

TA貢獻1828條經驗 獲得超3個贊
在不增加 regex 額外復雜性的情況下,您可以遍歷文件中的行并執行檢查Test12并Correct使用常規字符串方法:
var results = new List<string>();
using (var sr = new StreamReader(filepath, true))
{
var line = "";
while ((line=sr.ReadLine()) != null)
{
if (line.Contains("Correct") && !line.Contains("Test12"))
{
var res = Regex.Match(line, @"\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2,}(?:,\d{3}\b)?");
if (res.Success)
{
results.Add(res.Value);
}
}
}
}
使用正則表達式,如果要檢查是否存在的單詞出現在使用日期之后
\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2,}(?:,\d{3}\b)?(?!.*Test12)(?=.*Correct)
^^^^^^^^^^^^^^^^^^^^^^^^^
請參閱正則表達式演示。
在這里,(?!.*Test12)(?=.*Correct)先行確保 1) 沒有Test12和 2)Correct在當前位置右側(即日期之后)除換行符之外的任何 0+ 個字符之后有一個子字符串。
如果這些詞可能出現在字符串中的任何位置,您可以使用
(?m)\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2,}(?:,\d{3}\b)?(?=.*\r?$(?<!Test12.*)(?<=Correct.*))
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
請參閱此正則表達式演示。
在這里,該(?m)選項將 設置RegexOptions.Multiline為true以便$可以將其解析為行尾錨點,并且(?=.*\r?$(?<!Test12.*)(?<=Correct.*))正向先行執行以下檢查:它要求到行尾為止有 0+ 個字符,然后,在在該行的末尾,這兩個檢查是使用后視執行的:負后視(?<!Test12.*)確保一行中沒有Test12 任何地方,而正后視(?<=Correct.*)確保一行中的任何地方Correct都有子字符串。
可選的\r?CR before$是必需的,因為一個相當煩人的事實是在多行模式下$不匹配 before \r。

TA貢獻1993條經驗 獲得超6個贊
我認為您的意思是第 3 行和第 6 行匹配,因為第 5 行不包含Correct
.
要不包含“Test12”,您可以使用否定前瞻。要在之后匹配“正確”,您可以在您的模式中匹配它并使用單詞邊界\b
來防止它成為更大單詞的一部分。
您的模式可能如下所示:
^(?!.*\bTest12\b).*?(\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2,}(?:,\d{3}\b)?).*\bCorrect\b.*$
這將匹配:
^
字符串的開始(?!.*\bTest12\b)
斷言以下內容不包含Test12
.*?
匹配任何非貪婪的字符(\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2,}(?:,\d{3}\b)?)
在一個組中捕獲像模式一樣的日期.*
匹配任意字符 0+ 次\bCorrect\b
匹配正確.*
匹配任意字符 0+ 次$
字符串的結尾
筆記
這部分是否也應該像查看示例數據(?:,\d{3}\b)?
一樣匹配逗號前的數字?(?:\d,\d{3}\b)?

TA貢獻1807條經驗 獲得超9個贊
這是沒有正則表達式的一種方法。日期看起來不正確。我認為逗號位置錯誤,所以我修復了它。
DateTime today = DateTime.Parse("2019-01-22 15:36:14");
string input =
"2019-01-22 15:36:14,1023: [Test][123] INFORMATION - Testing: Correct Test12 ping\n" +
"2019-01-22 15:36:14,1023: [Test][124323] INFORMATION - Testing: Wrong Test12 ping\n" +
"2019-01-22 15:36:14,1023: [Test][12554363] INFORMATION - Testing: Correct Test ping\n" +
"2019-01-22 15:36:14,1023: [Test][6761213] INFORMATION - Testing: Wrong Test12 ping\n" +
"2019-01-22 15:36:14,1023: [Test][46543123] INFORMATION - Testing: Invalid Test ping\n" +
"2019-01-22 15:36:14,1023: [Test][887] INFORMATION - Testing: Correct Test ping";
StringReader reader = new StringReader(input);
string line = "";
while ((line = reader.ReadLine()) != null)
{
string[] splitDate = line.Split(new string[] { ": [Test]" }, StringSplitOptions.None);
DateTime date = DateTime.ParseExact(splitDate[0].Replace(",","."), "yyyy-MM-dd HH:mm:ss.FFFF", System.Globalization.CultureInfo.InvariantCulture);
string[] splitTest = splitDate[1].Split(new char[] { ':' });
if ((date.Date == today.Date) && splitTest[1].Contains("Correct") && !splitTest[1].Contains("Test12"))
{
Console.WriteLine(line);
}
}
Console.ReadLine();
- 3 回答
- 0 關注
- 121 瀏覽
添加回答
舉報