it-swarm.com.ru

Как я могу grep рекурсивно?

Как мне рекурсивно grep все каталоги и подкаталоги?

find . | xargs grep "texthere" *
1546
wpiri
grep -r "texthere" .

Первый параметр представляет регулярное выражение для поиска, а второй представляет каталог, в котором нужно искать. В этом случае . означает текущий каталог.

Примечание. Это работает для GNU grep, и на некоторых платформах, таких как Solaris, вы должны специально использовать GNU grep, а не в устаревшей реализации. Для Solaris это команда ggrep.

2328
Vinko Vrsalovic

Если вы знаете расширение или шаблон файла, который вам нужен, другой способ - использовать параметр --include:

grep -r --include "*.txt" texthere .

Вы также можете упомянуть файлы, которые нужно исключить, с помощью --exclude.

Ag

Если вы часто просматриваете код, Ag (The Silver Searcher) - это гораздо более быстрая альтернатива grep, она настроена для поиска кода. Например, по умолчанию он рекурсивен и автоматически игнорирует файлы и каталоги, перечисленные в .gitignore, поэтому вам не нужно постоянно передавать одни и те же громоздкие параметры исключения для grep или find.

628
christangrant

Также:

find ./ -type f -print0 | xargs -0 grep "foo"

но grep -r - лучший ответ.

121
Kurt

Теперь я всегда использую (даже в Windows с GoW - Gnu в Windows ):

grep --include="*.xxx" -nRHI "my Text to grep" *

Это включает в себя следующие параметры:

--include=PATTERN

Рекурсировать в каталогах только для поиска файла, соответствующего PATTERN.

-n, --line-number

Префикс каждой строки вывода с номером строки в своем входном файле.

(Примечание: phuclv добавляет в комментариях что -n сильно снижает производительность , так что вы можете пропустить эту опцию)

-R, -r, --recursive

Читать все файлы в каждом каталоге, рекурсивно; это эквивалентно опции -d recurse.

-H, --with-filename

Напечатайте имя файла для каждого соответствия.

-I     

Обрабатывать двоичный файл так, как будто он не содержит совпадающих данных;
это эквивалентно опции --binary-files=without-match.

И я могу добавить 'i' (-nRHIi), если я хочу получить результаты без учета регистра.

Я могу получить:

/home/vonc/gitpoc/passenger/gitlist/github #grep --include="*.php" -nRHI "hidden" *
src/GitList/Application.php:43:            'git.hidden'      => $config->get('git', 'hidden') ? $config->get('git', 'hidden') : array(),
src/GitList/Provider/GitServiceProvider.php:21:            $options['hidden'] = $app['git.hidden'];
tests/InterfaceTest.php:32:        $options['hidden'] = array(self::$tmpdir . '/hiddenrepo');
vendor/klaussilveira/gitter/lib/Gitter/Client.php:20:    protected $hidden;
vendor/klaussilveira/gitter/lib/Gitter/Client.php:170:     * Get hidden repository list
vendor/klaussilveira/gitter/lib/Gitter/Client.php:176:        return $this->hidden;
...
107
VonC

В системах POSIX вы не найдете параметр -r для grep, и ваш grep -rn "stuff" . не запустится, но если вы используете команду find, она будет:

find . -type f -exec grep -n "stuff" {} \; -print

Согласовано с Solaris и HP-UX.

21
rook

globbing **

Использование grep -r работает, но может привести к перегрузке, особенно в больших папках.

Для более практического использования, вот синтаксис, который использует globbing синтаксис (**):

grep "texthere" **/*.txt

который greps только определенные файлы с шаблоном выбранного шаблона. Это работает для поддерживаемых оболочек, таких как Bash +4 или zsh .

Чтобы активировать эту функцию, запустите: shopt -s globstar.

Смотрите также: Как мне найти все файлы, содержащие определенный текст в Linux?

git grep

Для проектов под управлением версией Git используйте:

git grep "pattern"

что намного быстрее.

ripgrep

Для больших проектов самый быстрый инструмент поиска - ripgrep , который по умолчанию рекурсивно обрабатывает файлы:

rg "pattern" .

Он построен на основе механизм регулярных выражений Rust , который использует конечные автоматы, SIMD и агрессивные буквальные оптимизации, чтобы сделать поиск очень быстрым. Проверьте подробный анализ здесь .

17
kenorb

Чтобы найти имя files с path рекурсивно, содержащим конкретную string, используйте приведенную ниже команду для UNIX:

find . | xargs grep "searched-string"

для Linux:

grep -r "searched-string" .

найти файл на сервере UNIX

find . -type f -name file_name

найти файл на сервере LINUX

find . -name file_name
11
Girdhar Singh Rathore

просто имена файлов тоже могут быть полезны

grep -r -l "foo" .
10
chim

Если вы хотите следовать только фактическим каталогам, а не символическим ссылкам,

grep -r "thingToBeFound" directory

Если вы хотите следовать символическим ссылкам, а также фактическим каталогам (будьте осторожны с бесконечной рекурсией),

grep -R "thing to be found" directory

Поскольку вы пытаетесь выполнить рекурсивный grep, вам также могут быть полезны следующие опции:

-H: outputs the filename with the line

-n: outputs the line number in the file

Поэтому, если вы хотите найти все файлы, содержащие Дарта Вейдера, в текущем каталоге или любых подкаталогах и захватить имя файла и номер строки, но не хотите, чтобы рекурсия следовала по символическим ссылкам, команда будет

grep -rnH "Darth Vader" .

Если вы хотите найти все упоминания о Word cat в каталоге

/home/adam/Desktop/TomAndJerry 

и вы в настоящее время в каталоге

/home/adam/Desktop/WorldDominationPlot

и вы хотите захватить имя файла, но не номер строки любого экземпляра строки "cats", и вы хотите, чтобы рекурсия следовала по символическим ссылкам, если она их находит, вы можете запустить любой из следующих

grep -RH "cats" ../TomAndJerry                   #relative directory

grep -RH "cats" /home/adam/Desktop/TomAndJerry   #absolute directory

Источник:

работает "grep --help"

Краткое введение в символические ссылки для всех, кто читает этот ответ и смущен моей ссылкой на них: https://www.nixtutor.com/freebsd/understanding-symbolic-links/

9
SarcasticSully

ag - мой любимый способ сделать это сейчас github.com/ggreer/the_silver_searcher . Это в основном то же самое, что и ack, но с еще несколькими оптимизациями.

Вот краткий тест. Я очищаю кэш перед каждым тестом (cf https://askubuntu.com/questions/155768/how-do-i-clean-or-disable-the-memory-cache )

[email protected]$ sync && echo 3 | Sudo tee /proc/sys/vm/drop_caches
3
[email protected]$ time grep -r "hey ya" .

real    0m9.458s
user    0m0.368s
sys 0m3.788s
[email protected]:$ sync && echo 3 | Sudo tee /proc/sys/vm/drop_caches
3
[email protected]$ time ack-grep "hey ya" .

real    0m6.296s
user    0m0.716s
sys 0m1.056s
[email protected]$ sync && echo 3 | Sudo tee /proc/sys/vm/drop_caches
3
[email protected]$ time ag "hey ya" .

real    0m5.641s
user    0m0.356s
sys 0m3.444s
[email protected]$ time ag "hey ya" . #test without first clearing cache

real    0m0.154s
user    0m0.224s
sys 0m0.172s
8
dranxo

Это тот, который работал для моего случая на моей текущей машине (git bash на windows 7):

find ./ -type f -iname "*.cs" -print0 | xargs -0 grep "content pattern"

Я всегда забываю -print0 и -0 для путей с пробелами.

Правка: мой предпочтительный инструмент теперь вместо ripgrep: https://github.com/BurntSushi/ripgrep/releases . Это действительно быстро и имеет лучшие значения по умолчанию (как рекурсивный по умолчанию). Тот же пример, что и мой оригинальный ответ, но с использованием ripgrep: rg -g "*.cs" "content pattern"

6
arkod

Если вы ищете определенный контент во всех файлах из структуры каталогов, вы можете использовать find, так как это более понятно, что вы делаете:

find -type f -exec grep -l "texthere" {} +

Обратите внимание, что -l (нижний регистр L) показывает имя файла, который содержит текст. Удалите его, если вместо этого вы хотите напечатать соответствие. Или используйте -H, чтобы получить файл вместе с совпадением. Все вместе, другие альтернативы:

find -type f -exec grep -Hn "texthere" {} +

Где -n печатает номер строки.

6
fedorqui

Это должно работать:

grep -R "texthere" *
5
sumit kumar

grep -r "texthere" . (период уведомления в конце)

(^ credit: https://stackoverflow.com/a/1987928/1438029 )


Разъяснение:

grep -r "texthere" / (рекурсивно grep все каталоги и подкаталоги)

grep -r "texthere" . (рекурсивно grep эти каталоги и подкаталоги)

grep рекурсивный

grep [options] PATTERN [FILE...]

[опции]

-R, -r, --recursive

Читать все файлы в каждом каталоге, рекурсивно.

Это эквивалентно опции -d recurse или --directories=recurse.

http://linuxcommand.org/man_pages/grep1.html

grep помогите

$ grep --help

$ grep --help |grep recursive
  -r, --recursive           like --directories=recurse
  -R, --dereference-recursive

Альтернативы

ack ( http://beyondgrep.com/ )

ag ( http://github.com/ggreer/the_silver_searcher )

4
Geoffrey Hale

На моем сервере IBM AIX (версия ОС: AIX 5.2) используйте:

find ./ -type f -print -exec grep -n -i "stringYouWannaFind" {} \; 

это выведет путь/имя файла и относительный номер строки в файле, например:

./inc/xxxx_x.h

2865:/** Описание: stringYouWannaFind * /

во всяком случае, у меня это работает :)

3
user3606336

Ниже приведена команда для поиска String рекурсивно в среде Unix и Linux.

для UNIX команда:

find . -name "string to be searched" -exec grep "text" "{}" \;

для Linux команда:

grep -r "string to be searched" .
3
Girdhar Singh Rathore

Я думаю, это то, что вы пытаетесь написать

grep myText $(find .)

и это может быть что-то еще полезное, если вы хотите найти файлы grep hit

grep myText $(find .) | cut -d : -f 1 | sort | uniq
2
Victor Faria

В 2018 году вы хотите использовать ripgrep или the-silver-searcher, потому что они намного быстрее, чем альтернативы.

Вот каталог с 336 подкаталогами первого уровня:

% find . -maxdepth 1 -type d | wc -l
     336

% time rg -w aggs -g '*.py'
...
rg -w aggs -g '*.py'  1.24s user 2.23s system 283% cpu 1.222 total

% time ag -w aggs -G '.*py$'
...
ag -w aggs -G '.*py$'  2.71s user 1.55s system 116% cpu 3.651 total

% time find ./ -type f -name '*.py' | xargs grep -w aggs
...
find ./ -type f -name '*.py'  1.34s user 5.68s system 32% cpu 21.329 total
xargs grep -w aggs  6.65s user 0.49s system 32% cpu 22.164 total

В OSX это устанавливает ripgrep: brew install ripgrep. Это устанавливает silver-searcher: brew install the_silver_searcher.

2
hughdbrown

Для списка доступных флагов:

grep --help 

Возвращает все совпадения для текста регулярного выражения здесь в текущем каталоге с соответствующим номером строки:

grep -rn "texthere" .

Возвращает все совпадения для текста здесь , начиная с корневого каталога, с соответствующим номером строки и игнорируя регистр:

grep -rni "texthere" /

здесь используются флаги:

  • -r рекурсивный
  • -n вывести номер строки с выводом
  • -i игнорировать регистр
2
JSON C11

Обратите внимание, что решения find . -type f | xargs grep whatever будут приводить к ошибкам "Список аргументов для длинных", когда слишком много файлов совпадают с поиском.

Лучшая ставка - grep -r, но если она недоступна, используйте вместо нее find . -type f -exec grep -H whatever {} \;.

1
m.thome

Просто для удовольствия, быстрый и грязный поиск файлов * .txt, если ответ @christangrant слишком велик для ввода :-)

grep -r texthere .|grep .txt

1
PJ Brunet

Вот рекурсивная (слегка протестированная с bash и sh) функция, которая перебирает все подпапки данной папки ($ 1) и использует grep для поиска заданной строки ($ 3) в заданных файлах ($ 2):

$ cat script.sh
#!/bin/sh

cd "$1"

loop () {
    for i in *
    do
        if [ -d "$i" ]
        then
            # echo entering "$i"
            cd "$i"
            loop "$1" "$2"
        fi
    done

    if [ -f "$1" ]
    then
        grep -l "$2" "$PWD/$1"
    fi

    cd ..
}

loop "$2" "$3"

Запуск и пример вывода:

$ sh script start_folder filename search_string
/home/james/start_folder/dir2/filename
0
James Brown