Команда grep
Серверы на базе операционной системы Linux обычно не имеют графического интерфейса по соображениям безопасности. Поэтому каждый, кто собирается самостоятельно управлять сервером должен уметь работать с терминалом Linux.
Очень полезная операция, которую мы можем выполнить с помощью терминала — это поиск внутри текстового файла. Особенно, если это — работа с файлами конфигурации таких сервисов, как NTP.
В этом коротком руководстве покажу, как использовать команду grep в Linux (Unix). А также подкрепим теоретический материал полезными примерами из повседневного рабочего процесса.
Как использовать команду Grep?
Принадлежащая к семейству Unix команда grep является одним из самых универсальных и полезных инструментов. Эта утилита выполняет поиск в текстовом файле по заданному шаблону. Другими словами, с помощью grep Вы можете найти необходимое Вам слово или значение. А содержащие Ваш запрос строки или строка будут выведены в терминал.
На первый взгляд, может показаться, что эта утилита имеет слишком узкое применение. Однако она способна значительно облегчить жизнь системным администраторам, которым приходится обрабатывать множество служб с различными файлами конфигурации. С помощью команды они могут быстро найти необходимые им строки в этих файлах.
Синтаксис команды grep при поиске в одном файле выглядит следующим образом:
grep [опции] значение [ФАЙЛ]grep — команда запуска утилиты командной строки
[опции] — модификаторы команды
значение — поисковый текстовый запрос
[ФАЙЛ] — файл, в котором выполняется поиск
Вы можете просмотреть документацию и пояснения к различным опциям команды, введя в командной строке:
grep –helpКак видите, команда предлагает нам множество опций. Однако наиболее важными и часто используемыми являются параметры:
-i — поиск не будет чувствителен к регистру. То есть, если Вы хотите найти слово «автомобиль», написанные как «АВТОМОБИЛЬ» слова тоже будут найдены.
-c — иногда вместо фактического совпадения со строкой требуется количество успешных совпадений, найденных grep
-r — часто требуется выполнить поиск в файлах не только в текущем рабочем каталоге, но и в подкаталогах.
-n — если нужно напечатать номера найденных строк, чтобы узнать их позицию в файле
—m[количество] — для больших файлов вывод может быть огромным и тогда понадобится фиксированное количество строк вместо всей «простыни»
-v — обратный поиск, выводит только строки, в которых нет указанного поискового запроса
-w — вместо частичного совпадения необходимо полное соответствие поисковому слову
Полезные примеры Grep
Давайте разберём несколько практических примеров команды grep.
Поиск слова в текстовом файле
Чтобы найти слово в текстовом файле, просто введите команду:
grep запрос файлзапрос — слово, которое вы ищете
файл — файл, в котором вы ищете слово
В нашем случае мы ищем слово command в файле с именем grep:
grep command grepПоиск слово, игнорируя регистр
Для этого необходимо добавить опцию -i.
grep -i запрос файлКоличество найденных слов по целевому запросу
Используя эту команду, вы также можете узнать, сколько раз определённое слово используется в текстовом файле. Просто добавьте опцию -c.
grep -c запрос файлПоиск по нескольким ключевым словам
До сих пор мы искали только одно слово. Однако grep позволяет использовать несколько поисковых запросов в одной команде. Вот как это выглядит:
grep запрос1 файл | grep запрос2 файлКоманда работает очень просто. Сначала ищется запрос1, а затем с помощью вертикальной черты и grep продолжаем поиск второго слова — запрос2.
Поиск слова в нескольких файлах
Также вы можете искать слово в нескольких файлах одновременно с помощью одной команды:
grep -l слово_которое_ищется *Файлы, содержащие слово, которое вы искали, будут выведены в терминал.
Итоги
Команда grep может значительно упростить жизнь, если мы работаем с большим количеством текстовых файлов. Вот почему на первый взгляд простая утилита grep считается универсальной командой с множеством полезных функций.
