我正在寻找PowerShell等价于grep——file=filename。如果你不知道grep, filename是一个文本文件,其中每一行都有一个你想要匹配的正则表达式模式。

也许我遗漏了一些明显的东西,但是Select-String似乎没有这个选项。


当前回答

我不熟悉grep,但选择字符串你可以做:

Get-ChildItem filename.txt | Select-String -Pattern <regexPattern>

你也可以使用Get-Content:

(Get-Content filename.txt) -match 'pattern'

其他回答

Select-String中的-Pattern参数支持模式数组。所以你要找的是

Get-Content .\doc.txt | Select-String -Pattern (Get-Content .\regex.txt)

它通过使用regex.txt中的每个regex(每行一个)来搜索文本文件doc.txt

所以我在这个链接上找到了一个很好的答案: https://www.thomasmaurer.ch/2011/03/powershell-search-for-string-or-grep-for-powershell/

但本质上是:

Select-String -Path "C:\file\Path\*.txt" -Pattern "^Enter REGEX Here$"

这在PowerShell的一行中提供了目录文件搜索(*或者您可以只指定一个文件)和文件内容搜索,非常类似于grep。输出将类似于:

doc.txt:31: Enter REGEX Here
HelloWorld.txt:13: Enter REGEX Here

也许?

[regex]$regex = (get-content <regex file> |
foreach {
          '(?:{0})' -f $_
        }) -join '|'

Get-Content <filespec> -ReadCount 10000 |
 foreach {
           if ($_ -match $regex)
             {
              $true
              break
             }
         }

这个问题已经有了答案,但我只想补充一点,在Windows中有Windows子系统for Linux WSL。

例如,如果你想检查名为Elasicsearch的服务是否处于运行状态,你可以在powershell中执行如下代码片段所示的操作

netstart | grep Elasticsearch

我通过PowerShell的“filter”和“alias”找到了一个可能的方法,当你想在管道输出中使用grep时(grep文件应该类似):

首先定义一个过滤器:

filter Filter-Object ([string]$pattern) {
    Out-String -InputObject $_ -Stream | Select-String -Pattern "$pattern"
}

然后定义别名:


    New-Alias -Name grep -Value Filter-Object

最后,将前一个过滤器和别名放在你的配置文件中:

$ Home \ PowerShell \ Microsoft.PowerShell_profile.ps1[我]文档

重启你的PS,这样你就可以使用它了:

别名| grep“grep”


参考文献

别名: Set-Alias这里 在这里新别名 过滤器(特殊功能)在这里 概要文件(就像bash的.bashrc):这里 Out-string(这是关键): 在PowerShell Output中是基于对象的,所以键 是将对象转换为字符串并grep字符串。 选择string: 在字符串和文件中查找文本