我需要在Windows中执行递归grep,在Unix / Linux中是这样的:
grep -i 'string' `find . -print`
或更优选的方法:
find . -print | xargs grep -i 'string'
我只使用cmd.exe,所以我只有Windows内置命令。我不能在此服务器上安装Cygwin或任何第三方工具,例如UnxUtils。我甚至不确定我是否可以安装PowerShell。任何建议只使用cmd.exe内置插件(Windows 2003 Server)?
答案 0 :(得分:234)
findstr
可以执行递归搜索(/ S)并支持一些正则表达式语法(/ R)的变体。
C:\>findstr /?
Searches for strings in files.
FINDSTR [/B] [/E] [/L] [/R] [/S] [/I] [/X] [/V] [/N] [/M] [/O] [/P] [/F:file]
[/C:string] [/G:file] [/D:dir list] [/A:color attributes] [/OFF[LINE]]
strings [[drive:][path]filename[ ...]]
/B Matches pattern if at the beginning of a line.
/E Matches pattern if at the end of a line.
/L Uses search strings literally.
/R Uses search strings as regular expressions.
/S Searches for matching files in the current directory and all
subdirectories.
/I Specifies that the search is not to be case-sensitive.
/X Prints lines that match exactly.
/V Prints only lines that do not contain a match.
/N Prints the line number before each line that matches.
/M Prints only the filename if a file contains a match.
/O Prints character offset before each matching line.
/P Skip files with non-printable characters.
/OFF[LINE] Do not skip files with offline attribute set.
/A:attr Specifies color attribute with two hex digits. See "color /?"
/F:file Reads file list from the specified file(/ stands for console).
/C:string Uses specified string as a literal search string.
/G:file Gets search strings from the specified file(/ stands for console).
/D:dir Search a semicolon delimited list of directories
strings Text to be searched for.
[drive:][path]filename
Specifies a file or files to search.
Use spaces to separate multiple search strings unless the argument is prefixed
with /C. For example, 'FINDSTR "hello there" x.y' searches for "hello" or
"there" in file x.y. 'FINDSTR /C:"hello there" x.y' searches for
"hello there" in file x.y.
Regular expression quick reference:
. Wildcard: any character
* Repeat: zero or more occurrences of previous character or class
^ Line position: beginning of line
$ Line position: end of line
[class] Character class: any one character in set
[^class] Inverse class: any one character not in set
[x-y] Range: any characters within the specified range
\x Escape: literal use of metacharacter x
\<xyz Word position: beginning of word
xyz\> Word position: end of word
For full information on FINDSTR regular expressions refer to the online Command
Reference.
答案 1 :(得分:112)
findstr /spin /c:"string" [files]
参数具有以下含义:
s
= recursive p
=跳过不可打印的字符i
=不区分大小写n
=打印行号要搜索的字符串是您在/c:
答案 2 :(得分:22)
我刚用以下命令搜索了一个文本,该命令列出了包含我指定的“搜索文本”的所有文件名。
C:\Users\ak47\Desktop\trunk>findstr /S /I /M /C:"search text" *.*
答案 3 :(得分:12)
我推荐一个非常棒的工具:
native unix utils:
只需解压缩它们并将该文件夹放入PATH环境变量即可! :)
像魅力一样工作,还有更多只是grep;)
答案 4 :(得分:9)
for /f %G in ('dir *.cpp *.h /s/b') do ( find /i "what you search" "%G") >> out_file.txt
答案 5 :(得分:8)
递归搜索import
文件夹中的src
个字词:
> findstr /s import .\src\*
答案 6 :(得分:5)
Select-String
对我来说效果最好。此处列出的所有其他选项(例如findstr
)不适用于大文件。
以下是一个例子:
select-string -pattern "<pattern>" -path "<path>"
注意:这需要Powershell
答案 7 :(得分:3)
如果您安装了Perl,则可以使用http://beyondgrep.com/处提供的确认。