VB Net RegEx 匹配多个

VB Net RegEx Match Multiple

我正在尝试将多行与 RegEx 匹配以组合在一起。这是我正在搜索的文本示例:

Total
2015
DOLLAR
AMOUNT
Oct-15 DIFF 15-16
Total
2015
COMPANY 1 - WI
Nuts $ 59.85 $ 0.00 $ 135.45 $ 0.00 $ 135.45 [=11=].00
Bolts $ 0.00 $ 0.00 $ 0.00 $ 0.00 $ 0.00 [=11=].00
Screws $ 449.20 $ 0.00 $ 541.23 $ 0.00 $ 541.23 [=11=].00
Total 7765: $ 509.05 $ 0.00 $ 676.68 $ 0.00 $ 676.68 [=11=].00
Company 2 - NE
Nuts $ 0.00 $ 0.00 $ 0.00 $ 0.00 $ 0.00 [=11=].00
Bolts $ 0.00 $ 55.67 $ 542.48 $ 719.82 $(177.34) 7.02
Total 1876: $ 0.00 $ 55.67 $ 2,960.52 $ 4,265.82 $(1,305.30) ,854.60
Company 3 - MN
Nuts $ 109.52 $ 606.52 $ 858.36 $ 606.52 $ 251.84 6.52
Paper $ 0.00 $ 0.00 $ 483.82 $ 0.00 $ 483.82 8.30
Gas $ 0.00 $ 0.00 $ 0.00 $ 0.00 $ 0.00 [=11=].00
OTHER $ 521.49 $ 0.00 $ 521.49 $ 0.00 $ 521.49 [=11=].00
Total 6524: $ 631.01 $ 606.52 $ 3,909.09 $ 606.52 $ 3,302.57 ,284.82
Company 4 - IA
Anything $ 0.00 $ 0.00 $ 0.00 $ 0.00 $ 0.00 [=11=].00
Other $ 0.00 $ 0.00 $ 171.90 $ 0.00 $ 171.90 [=11=].00
Total 1123: $ 0.00 $ 0.00 $ 171.90 $ 0.00 $ 171.90 [=11=].00

我正在尝试将公司名称和总行分组拉出。如果我将它设置为多行并使用

^(.+?\s-\s.{2})$

这会让我得到公司名称。我也试过这个:

^(.+\s-\s\w{2}|Total\s\d{1,5}:.+)$

两条线都可以,但它们都作为第 1 组通过。有没有办法确保它们匹配?那么第 1 组是公司名称,第 2 组是总行?我尝试在中间添加类似的内容,但它没有用,因为公司和总行之间的行数不同。

^(.+\s-\s\w{2})$(^.+$){1,20}^(Total\s\d{1,5}:.+)$

(我不记得我到底有什么,但它给了我中间的线..只是它们的数量并不总是正确的。)有没有办法跳过公司名称和他们之间的那些线各自的总行,组1是客户名,组2是总行?

试试这个:

^(.+\s-\s\w{2})$|^(Total\s\d{1,5}:.+)$

演示:https://regex101.com/r/8r8ZS0/1

我得到了我想要的东西:

^(.*\s-\s\w{2})$\n(^.+$\n)+?^Total\s(\d{2,5}:.+)$

它给了我组 1 中的客户名称和组 3 中的总行,我可以忽略组 2。谢谢。