我有一个包含多行数据的文本文件。我可以使用以下powershell脚本来提取我感兴趣的行:
select-string -path *.txt -pattern "subject=([A-Z\.]+),"
以下是一些示例数据:
blah blah subject=THIS.IS.TEST.DATA, blah blah blah
我想要的是能够提取主题的实际内容(即"THIS.IS.TEST.DATA“字符串)。我试过这个:
select-string -path *.txt -pattern "subject=([A-Z\.]+)," | %{ $_.Matches[0] }
但是"Matches“属性总是空的。我做错了什么?
发布于 2009-03-05 13:20:58
我不知道为什么你的版本不起作用。应该能行得通。这是一个更丑陋的版本。
$p = "subject=([A-Z\.]+),"
select-string -path *.txt -pattern $p | % {$_ -match $p > $null; $matches[1]}
解释:
-match
是正则表达式匹配运算符:
>"foobar" -match "oo.ar"
True
> $null
只是禁止向输出中写入True。(尝试删除它。)有一个cmdlet做同样的事情,我现在记不起它的名字了。
$matches
是一个神奇的变量,它保存最后一次-match
操作的结果。
发布于 2010-01-28 23:03:13
在PowerShell V2 CTP3中,实现了Matches属性。因此,下面的方法将会起作用:
select-string -path *.txt -pattern "subject=([A-Z\.]+)," | %{ $_.Matches[0].Groups[1].Value }
发布于 2009-03-05 14:20:21
还有另一个选择
gci *.txt | foreach { [regex]::match($_,'(?<=subject=)([^,]+)').value }
https://stackoverflow.com/questions/614651
复制相似问题