GREP(1) Команди користувача GREP(1)

НАЗВА

grep, egrep, fgrep - вивід рядків узгоджених із зразком

КОРОТКИЙ ОПИС

grep [ПАРАМЕТР...] ЗРАЗОК [ФАЙЛ...]
grep [ПАРАМЕТР...] -e ЗРАЗОК ... [ФАЙЛ...]
grep [ПАРАМЕТР...] -f ФАЙЛ_ВЗІРЦІВ ... [ФАЙЛ...]

ОПИС

grep шукає відповідність зі ЗРАЗКОМ у кожному ФАЙЛІ. ЗРАЗОК – це один або кілька шаблонів, розділених символами нового рядка, а grep виводить кожен рядок, який відповідає шаблону. Зазвичай, коли grep використовується в командній оболонці, ШАБЛОН слід вводити в лапках.

ФАЙЛ із “-” означає стандартне введення. Якщо ФАЙЛ не вказано, рекурсивний пошук перевіряє поточний каталог, а нерекурсивний зчитує стандартне введення.

Крім того, варіанти програм egrep та fgrep роблять те саме, що й grep -E та grep -F відповідно. Ці варіанти не підтримуються, але надаються для зворотної сумісності.

ПАРАМЕТРИ

Загальна інформація про програму

Виводить повідомлення щодо користування програмою та закривається.
Виводить номер версії grep.

Синтаксис шаблонів

ЗРАЗОК розглядається як розширені регулярні вирази (ERE, див. нижче).
ЗРАЗОК розглядається як фіксовані рядки, а не регулярні вирази.
ЗРАЗОК інтерпретується як основні регулярні вирази (BRE, див. нижче). Це є типове значення.
I<ЗРАЗОК> розглядається як Perl-сумісний формальний вираз (PCRE). Цей параметр є експериментальним у поєднанні з параметром -z (--null-data), а grep -P може попереджати про нереалізовані функції.

Контроль відповідності

ЗРАЗОК використовується як шаблон. Якщо цей параметр використовувати кілька разів або поєднати з параметром -f (--file), відшукуються усі задані зразки. Цей параметр можна використовувати для захисту зразка, який починається з “-”.
З ФАЙЛ, отримуються зразки по одному на рядок. Якщо цей параметр використовувати кілька разів або поєднати з параметром -e (--regexp), відшукуються усі задані зразки. Порожній файл не містить зразків, тому нічого не відповідає.
У зразках та вхідних даних ігнорується різниця регістру, щоб символи, які відрізняються лише регістром, вважалися відповідними.
У зразках та вхідних даних не ігнорується регістр. Це типове значення. Цей параметр корисний для передавання до скриптів оболонки, які вже використовують -i, для скасування його ефектів, оскільки ці два параметри перемикають один одного.
Параметр відповідності обертається, щоб вибирати невідповідні зразку рядки.
Вибираються лише ті рядки, що містять збіги, які утворюють цілі слова. Перевірка полягає в тому, що підрядок, який збігається, може знаходитися на початку рядка, або передувати символу, який не входить до складу слова. Так само він може бути в кінці рядка, або за ним може слідувати символ, який не входить до складу слова. Символами, що входять до складу слова, є літери, цифри та символ підкреслення. Цей параметр не діє, якщо також вказано -x.
Вибираються лише повністю відповідні зразку строки. Для зразка регулярного виразу це все одно, що помістити шаблон у круглі дужки, а потім оточити його ^ і $.
Застарілий синонім до -i.

Загальне керування виведенням

Пригнічує звичайний вивід; замість цього виводить кількість відповідних рядків для кожного файлу вводу. За допомогою параметра -v, --invert-match (див. нижче), виводить число рядків, які не збігаються.
Оточує відповідні (непорожні) рядки, відповідні рядки, контекстні рядки, імена файлів, номери рядків, зміщення байтів і роздільники (для полів і груп контекстних рядків) escape-послідовністю, щоб відобразити їх у кольорі в терміналі. Кольори визначаються змінною середовища GREP_COLORS. Застаріла змінна середовища GREP_COLOR все ще підтримується, але її налаштування не мають пріоритету. КОЛИ – це ніколи, завжди або auto.
Пригнічує звичайний вивід, натомість виводить назви файлів в яких збігів не відбулося. Пошук всередині кожного файлу припиняється після першого збігу.
Пригнічує звичайний вивід; натомість виводить назви файлів, що містять збіги. Пошук всередині кожного файлу припиняється після першого збігу.
Пошук у файлі припиняється після вказаного ЧИСЛА рядків, які збіглися. Якщо ввід відбувається зі звичайного файлу, grep зупинить пошук одразу ж на наступному рядку після останнього рядка, який збігається і припинить роботу. Це дозволяє поновити процес пошуку з місця зупинки. Коли grep зупиняється після вказаного ЧИСЛА відповідних рядків, він виводить будь-який наступний рядок. Якщо додатково використовується параметр -c або --count, grep не виводить кількість більшу, ніж ЧИСЛО. Коли додатково вживається параметр -v або --invert-match, grep зупиняється після виведення ЧИСЛА невідповідних рядків.
Виводить лише узгоджені (непорожні) частини відповідного рядка, причому кожний збіг виводиться в окремий рядок.
Мовчазний вивід; не виводить нічого в звичайному випадку. Негайно припиняє роботу із нульовим статусом, якщо знайдено будь-який збіг, навіть якщо була виявлена помилка. Також дивіться параметр -s або --no-messages.
Пригнічуються повідомлення про помилки щодо неіснуючих або недоступних файлів.

Управління Префіксом Вихідного Рядка

Ставить перед кожним рядком номер блоку, в якому він був знайдений, починаючи з 0. Якщо додатково вказати -o (--only-matching), виводить номер блоку найбільш відповідної частини.
Виводить назву файлу для кожного збігу. Це типове значення, якщо пошук виконують у декількох файлах. Це розширення GNU.
Пригнічує показ імен файлів у виводі. Це типове значення, якщо пошук проводиться лише в одному файлі (або стандартний ввід).
Вказує ніби ввід надходить з файла з назвою НАЗВА. Це може бути корисно для команд, які перетворюють вміст файлу перед пошуком, наприклад, gzip -cd foo.gz | grep --label=foo -H 'ЗРАЗОК'. Дивіться також параметр -H.
Виводить перед кожним рядком його номер у файлі (нумерація починається з 1).
Перевіряє, що перший символ фактичного вмісту рядка лежить на табуляції, щоб вирівнювання табуляторів виглядало нормально. Це корисно робити разом з параметрами, які передбачають вивід до фактичного вмісту: -H, -n і -b. Щоб підвищити ймовірність того, що всі рядки з одного файлу будуть починатися з одного стовпця, також друкується номер рядка та зміщення блоків (якщо воно є) у мінімальній ширині розміру поля.
Виведіть нульовий байт (символ ASCII NUL) замість символу, який зазвичай слідує після імені файлу. Наприклад, grep -lZ виводить нульовий байт після кожного імені файлу замість звичайного нового рядка. Ця опція забезпечує однозначний вивід, навіть у випадку назв файлів що містять незвичні знаки, такі як знак нового рядка. Ця опція може використовуватись разом з такими командами як find -print0, perl -0, sort -z та xargs -0 для обробки довільних назв файлів.

Контроль контексту рядка

Виводить ЧИСЛО рядків кінцевого контексту після відповідних рядків. Розміщує рядок із роздільником груп (--) між безперервними групами збігів. З опцією -o або --only-matching команда, про що виводиться попередження.
Виводить ЧИСЛО рядків початкового контексту перед відповідними рядками. Розміщує рядок із роздільником груп (--) між безперервними групами збігів. З опцією -o або --only-matching команда не працює, про що виводиться попередження.
Виводить ЧИСЛО рядків вихідного контексту. Розміщує рядок із роздільником груп (--) між безперервними групами збігів. З опцією -o або --only-matching команда не працює, про що виводиться попередження.
Коли використовуються опції -A, -B або -C, друкуйте РОЗДІЛЬНИК замість -- між групами рядків.
Коли використовуються опції -A, -B або -C, не друкуйте роздільник між групами рядків.

Вибір файлів і каталогів

Двійковий файл обробляється так, ніби це текст; це еквівалентно параметру --binary-files=text.
Якщо дані або метадані файлу вказують, що цей файл містить двійкові дані, припускається що файл має тип ТИП. Нетекстові байти вказують на двійкові дані; це або вихідні байти, які неправильно закодовані для поточної локалі, або нульові вхідні байти, якщо параметр -z не заданий.
Стандартним значенням ТИП є binary, а grep придушує виведення після виявлення нульових вхідних двійкових даних і пригнічує вихідні рядки, які містять неправильно закодовані дані. Коли деякий вихід пригнічено, grep виводить повідомлення, що цей файл є двійковим "binary file matches".
Якщо ТИП є without-match, коли grep виявляє нульові вхідні двійкові дані, вважатиметься що жодний файл не є двійковим, це відповідає опції -I..
Якщо ТИП є text, grep обробляє двійковий файл так, ніби це текст; це еквівалентно параметру -a.
Коли тип є binary, grep може розглядати нетекстові блоки як команди терміналу навіть без параметра -z. Це означає, що вибір binary замість text може вплинути на те, чи відповідає шаблон файлу. Наприклад, коли тип є binary, зразок q$ might відповідатиме q, за яким одразу слідує нульовий байт, навіть якщо він не співпадає, коли тип є text.
Попередження: Опція -a може виводити двійкове сміття, що може мати неприємні побічні ефекти, якщо результат виводиться у термінал і движок терміналу інтерпретує це як команди. З іншого боку, під час читання файлів, кодування тексту яких невідомі, може бути корисним використовувати -a або встановити у середовищі LC_ALL='C', щоб знайти більше збігів, навіть якщо збіги небезпечні для прямого показу.
Якщо вхідний файл є пристроєм, FIFO або сокетом, використовуйте ДІЯ для обробки вводу. Типово, ДІЯ має значення read, це означає, що пристрої читаються так само, ніби звичайні файли. Якщо ДІЯ має значення skip, пристрої ігноруються.
Якщо вхідний файл є каталогом, використовуйте для його обробки ДІЯ. Типовим значенням ДІЯ є read, тобто читати каталоги так, як якщо б вони були звичайними файлами. Якщо ДІЯ є skip, каталоги пропускаються "мовчки". Якщо ДІЯ є recurse, всі файли в кожному каталозі читаються рекурсивно, з переходом за символічними посиланнями, лише якщо вони знаходяться в командному рядку. Це подібно параметру -r.
Пропускає будь-який файл командного рядка із суфіксом імені, який відповідає шаблону ШАБЛОН ПОШУКУ, використовуючи підстановку; суфікс назви – це або ціла назва, або частина в кінці, яка починається з символу без косої риски відразу після косої риски (/) у назві. Під час рекурсивного пошуку пропускається будь-який файл, базова назва якого відповідає ШАБЛОН ПОШУКУ; базова назва — частина після останньої косої риски. Зразок може використовувати *, ? і [...] як символи підстановки та \ для буквального цитування символу підстановки або зворотної косої риски.
Пропускаються файли, базова назва яких збігається з будь-яким із назв файлів, зчитаних з ФАЙЛ (з використанням зіставлення підстановки, як описано в розділі --exclude).
Пропускається будь-який каталог командного рядка із суфіксом імені, який відповідає шаблону ШАБЛОН ПОШУКУ. Під час рекурсивного пошуку пропускайться будь-який підкаталог, базова назва якого відповідає ШАБЛОН ПОШУКУ. Будь-які зайві кінцеві косі риски в ШАБЛОН ПОШУКУ ігноруються.
Двійковий файл обробляється так, ніби він не містить відповідних даних; це еквівалентно параметру --binary-files=without-match.
Шукаються лише файли, базова назва яких відповідає ШАБЛОН ПОШУКУ (використовуючи відповідність підстановки, як описано в розділі --exclude).
Всі файли в кожному каталозі читаються рекурсивно, з переходами за символічними посиланнями, лише якщо вони знаходяться в командному рядку. Зауважте, що якщо не вказано операнд файлу, B<grep> пошук виконується в робочому каталозі. Це еквівалентно параметру -d recurse.
Рекурсивно читаються всі файли в кожному каталозі. Перехід за всіма символічними посиланнями робиться, на відміну від -r.

Інші параметри

Використовується буферизація рядків на виводі. Це може призвести до зниження продуктивності.
Файл(и) розглядається як двійковий. Типово, у системах MS-DOS та MS-Windows, grep вгадує, чи є файл текстовим чи двійковим, за описом у параметрі --binary-files. Якщо grep вирішить, що файл є текстовим, він видаляє CR знаки з оригінального файлу (щоб регулярні вирази з ^ і $ працювали правильно). Вказання -U скасовує вгадування, зумовлюючи прочитання всіх файлів і буквальну передачу їх механізму порівнювання; якщо це був текстовий із CR/LF парою наприкінці кожного рядка, це може призвести до розбіжності з деякими зразками. Цей параметр не впливає на інші платформи, крім MS-DOS і MS-Windows.
Ввідні та вихідні дані розглядаються як послідовності рядків, кожен з яких закінчується нульовим байтом (символом ASCII NUL) замість знака нового рядка. Так само як -Z або --null, цю опцію можна використовувати з такими командами, як sort -z для обробки довільних назв файлів.

РЕГУЛЯРНІ ВИРАЗИ

Регулярний вираз — це зразок, що описує набір текстових рядків. Регулярні вирази будуються аналогічно арифметичним, з використанням різних операторів для комбінації менших виразів.

grep розуміє три різні версії синтаксису регулярних виразів: “basic” (BRE), “extended” (ERE) та “perl” (PCRE) (базовий, розширений та perl). У GNU grep немає різниці в доступній функціональності для перших двох версій. В інших реалізаціях базові регулярні вирази менш потужні. Наступний опис стосується розширених регулярних виразів; після чого підсумовуються відмінності для базових регулярних виразів. Регулярні вирази, сумісні з Perl, надають додаткову функціональність і задокументовані в B<pcresyntax>(3) і B<pcrepattern>(3), але працюють лише за умови ввімкненої підтримки PCRE.

Основними складовими частинами є регулярні вирази, які відповідають одному символу. Більшість символів, включаючи всі літери та цифри, є регулярними виразами, які відповідають самі собі. Будь-який знак із спеціальним значенням може бути екрановано, якщо поставити перед ним обернений слеш.

Крапка . відповідає будь-якому окремому символу. Не вказується, чи відповідає він помилці кодування.

Класи Символів та Вирази в Дужках

вираз у дужках — це список символів, укладених між [ та ]. Це відповідає будь-якому окремому символу з цьому списку. Якщо першим символом списку є каретка ^, то він відповідає будь-якому символу якого немає у списку; чи він відповідає помилці кодуванні. Наприклад, регулярний вираз [0123456789] відповідає будь-якій одній цифрі.

Вираз в дужках діапазон виразу складається з двох символів, розділених дефісом. Він відповідає будь-якому окремому символу, який знаходиться між двома символами включно із цими символами, використовуючи послідовності відносно до локалі та набору символів. Наприклад, у стандартній локалі C, типово, [a-d] еквівалентно [abcd]. Є багато мовних локалей, які сортують символи в порядку словника, і в цих мовах [a-d] зазвичай не еквівалентне [abcd]; це може бути еквівалентним, наприклад, [aBbCcDd]. Щоб отримати традиційну інтерпретацію виразів у квадратних дужках, можна використовувати локаль C, встановивши для змінної середовища LC_ALL значення C.

Нарешті, певні іменовані класи символів попередньо визначені у виразах у дужках, як показано нижче. Їхні назви зрозумілі самі собою: [:alnum:], [:alpha:], [:blank:], [:cntrl:], [:digit :], [:graph:], [:lower:], [:print:], [:punct:], [:space:], [:upper:] і [:xdigit:]. Наприклад, [[:alnum:]] означає клас символів цифр та букв у поточній мові. У кодуванні мови C та набору символів ASCII це те саме, що [0-9A-Za-z]. (Зверніть увагу, що дужки в назвах класів є частиною символічних імен і повинні бути включені на додаток до дужок, що розмежовують вирази у дужках.) Більшість спеціальних знаків втрачають своє особливе значення всередині виразів у дужках. Щоб включити символ ], розмістіть його першим у списку. Аналогічно, щоб включити символ ^, розмістіть його спочатку списку. Нарешті, щоб включити символ -, поставте його останнім.

Прив'язування

Каретка ^ та знак долара $ є спеціальними символами, які позначають у порожньому рядку початок і кінець рядка відповідно.

Символ Зворотнього Слешу та Спеціальні Вирази

Символи \< і \> відповідно відповідають порожньому рядку на початку і в кінці слова. Символ \b відповідає порожньому рядку на краю слова, а \B відповідає порожньому рядку за умови, що це НЕ на краю слова. Символ \w є синонімом [_[:alnum:]], а \W є синонімом [^_[:alnum:]].

Повторення

За регулярним виразом може слідувати один з кількох операторів повторення:

?
Попередній елемент є необов'язковим і збігається не більше одного разу.
*
Попередній елемент буде збігатися нуль або більше разів.
+
Попередній елемент буде збігатися один або кілька разів.
{n}
Попередній елемент збігається точно n разів.
{n,}
Попередній елемент збігається n або більше разів.
{,m}
Попередній елемент збігається не більше m разів. Це розширення GNU.
{n,m}
Попередній елемент збігається щонайменше n разів, але не більше m разів.

Ланцюжок

Два регулярних вирази можуть бути об'єднані; отриманий регулярний вираз відповідає будь-якому рядку, утвореному шляхом зчеплення двох підрядків, які відповідно збігаються об'єднаним виразам.

Черговість

Два регулярні вирази можуть бути об'єднані за допомогою оператора |; отриманий регулярний вираз відповідає будь-якому рядку, що відповідає будь-якому альтернативному виразу.

Пріоритетність

Повторення має перевагу над ланцюжком, який, у свою чергу, має перевагу над черговістю. Щоб замінити ці правила пріоритету та сформувати підвираз, цілий вираз може бути узятий у дужки.

Зворотні посилання та підвирази

Зворотне посилання \n, де n є однією цифрою, відповідає підрядку, який раніше відповідав n-му підвиразу регулярного виразу в дужках.

Базові з Розширеними регулярні вирази

У базових регулярних виразах метасимволи ?, +, {, |, ( і ) втрачають своє особливе значення; замість цього використовуйте версії \?, \+, \{, \|, \( і \).

СТАН ВИХОДУ

Зазвичай статус виходу дорівнює 0, якщо вибрано рядок, 1, якщо рядки не вибрано, і 2, якщо сталася помилка. Однак якщо використовується -q або --quiet або --silent і вибрано рядок, статус виходу дорівнює 0, навіть якщо сталася помилка.

СЕРЕДОВИЩЕ

На поведінку grep впливають наступні змінні середовища.

Локаль для категорії LC_foo визначається шляхом вивчення трьох змінних середовища LC_ALL, LC_foo, LANG саме в такому порядку. Перша з цих змінних, яка встановлюється, визначає локаль. Наприклад, якщо LC_ALL не встановлено, але LC_MESSAGES встановлено на pt_BR, тоді для категорії LC_MESSAGES використовується бразильська португальська мова. Локаль C використовується, якщо жодна з цих змінних середовища не встановлена, якщо каталог мовних стандартів не встановлено, або якщо grep не було скомпільовано з підтримкою національної мови (NLS). Команда оболонки locale -a перелічує доступні на даний момент локалі.

Ця змінна визначає колір, який використовується для виділення відповідного (непорожнього) тексту. Це застаріла опція в GREP_COLORS, але вона ще підтримується. Можливості mt, ms і mc GREP_COLORS мають пріоритет над нею. Вона може лише вказати колір, який використовується для виділення відповідного непорожнього тексту в будь-якому відповідному рядку (вибраний рядок, коли параметр командного рядка -v опущено, або контекстний рядок, коли вказано -v). Типовим значенням є 01;31, що означає напівжирний червоний текст та типовий фон термінала.
Визначає кольори та інші атрибути, які використовуються для виділення різних частин виводу. Його значення — це список можливостей, розділений двокрапкою, який типово має значення ms=01;31:mc=01;31:sl=:cx=:fn=35:ln=32:bn=32:se=36 з логічні можливості rv і ne пропущені (тобто false). Підтримувані можливості наступні.
Підрядок SGR для цілих виділених рядків (тобто рядки, що збігаються, коли параметр командного рядка -v опущено, або невідповідні рядки, коли вказано -v). Проте, якщо вказано логічну можливість rv і параметр командного рядка -v, це застосовується натомість до рядків відповідності контексту.
Підрядок SGR для цілих рядків контексту (тобто невідповідні рядки, коли параметр командного рядка -v опущено, або відповідні рядки, коли вказано -v). Проте, якщо вказано логічну можливість rv і параметр командного рядка -v, вона застосовується замість цього до вибраних невідповідних рядків. Типово порожній (тобто типова пара кольорів термінала).
Логічне значення, яке змінює (міняє місцями) значення можливостей sl= і cx=, коли вказано параметр командного рядка -v. Типово — false (тобто можливість пропущена).
Підрядок SGR для збігу непорожнього тексту в будь-якому відповідному рядку (тобто виділений рядок, коли параметр командного рядка -v опущено, або контекстний рядок, коли вказано -v). Це налаштування еквівалентно одночасному встановленню одного значення для ms= і mc=. Типово — напівжирний червоний текст на поточному фоні рядка.
Підрядок SGR для збігу непорожнього тексту у виділеному рядку. (Використовується лише тоді, коли параметр командного рядка -v опущено.) Ефект від можливості sl= (або cx=, якщо rv) залишається активним, коли команда повторюється. Типово — напівжирний червоний текст на поточному фоні рядка.
Підрядок SGR для збігу непорожнього тексту в контекстному рядку. (Використовується лише тоді, коли вказано параметр командного рядка -v.) Ефект від можливості cx= (або sl=, якщо rv) залишається активним, коли команда. Типово — напівжирний червоний текст на поточному фоні рядка.
Підрядок SGR для назв файлів із префіксом рядка будь-якого вмісту. За замовчуванням текст пурпурового кольору на фоні терміналу.
Підрядок SGR для номерів рядків із префіксом рядка будь-якого вмісту. За замовчуванням текст зеленого кольору на фоні терміналу за замовчуванням.
Підрядок SGR для байтових зміщень із префіксом рядка будь-якого вмісту. За замовчуванням текст зеленого кольору на фоні терміналу за замовчуванням.
Підрядок SGR для роздільників, які вставляють між вибраними полями рядка (:), між полями рядка контексту, (-) та між групами суміжних рядків, коли вказано ненульовий контекст (--) . Типово блакитний текст на фоні терміналу за замовчуванням.
Логічне значення, яке запобігає очищенню до кінця рядка за допомогою Стерти в рядку (EL) Направо (\33[K) щоразу, коли закінчується розфарбований елемент. Це потрібно на терміналах, на яких EL не підтримується. Інакше кажучи це корисно на терміналах, для яких не застосовується логічна функція terminfo back_color_erase (bce), коли вибрані кольори виділення не впливають на фон, або коли EL надто повільний або викликає занадто сильне мерехтіння. Типово значення false (тобто можливість пропущена).

Зауважте, що логічні можливості не мають частини =.... Вони пропущені (тобто false) за замовчуванням і стають істинними, коли це вказано.

Дивіться розділ Select Graphic Rendition (SGR) у документації текстового терміналу, який використовується для дозволених значень та їх значення як атрибутів символів. Ці значення підрядка є цілими числами в десятковому представленні і можуть бути об'єднані крапкою з комою. grep забезпечує збірку результату в повну послідовність SGR (\33[...m). Загальні значення для об'єднання включають 1 для напівжирного, 4 для підкреслення, 5 для миготіння, 7 для інвертованого, 39 для кольору тексту за замовчуванням, 30 до 37 для кольорів тексту, 90 до 97 для 16-кольорового режиму кольорів тексту, 38;5;0 до 38;5;255 для кольорів тексту з 88 та 256 кольорів , 49 для кольору фону за замовчуванням, 40 до 47 для кольорів фону, 100 до 107 для 16-кольорового режиму кольорів фону та 48;5;0 до 48;5;255 для кольорів фону у режимах 88 та 256 кольорів.

Ці змінні визначають локаль для категорії LC_COLLATE, яка визначає послідовність символів, яка використовується для інтерпретації виразів діапазону, наприклад [a-z].
Ці змінні визначають локаль для категорії LC_CTYPE, яка визначає тип символів, наприклад, які символи є пробілами. Ця категорія також визначає кодування символів, тобто кодування тексту в UTF-8, ASCII чи іншому кодуванні. У мовному стандарті C або POSIX всі символи кодуються як один байт, і кожен байт є дійсним символом.
Ці змінні визначають локаль для категорії LC_MESSAGES, яка визначає мову, що grep використовується для повідомлень. Місцевий стандарт C за замовчуванням використовує повідомлення американською англійською мовою.
Якщо це встановлено, grep поводить себе так, як вимагає POSIX; інакше grep поводить себе більше як інші програми GNU. POSIX вимагає, щоб параметри, які йдуть за іменами файлів, розглядалися як імена файлів; за замовчуванням такі параметри переміщуються на початку списку операндів і розглядаються як параметри. Крім того, POSIX вимагає, щоб нерозпізнані параметри були діагностовані як "незаконні", але оскільки вони насправді не суперечать закону, за замовчуванням їх діагностують як "недійсні". POSIXLY_CORRECT також вимикає _N_GNU_nonoption_argv_flags_, описану нижче.
_N_GNU_nonoption_argv_flags_
(Тут N — числовий ідентифікатор процесу grep.) Якщо i-й символ значення цієї змінної середовища є 1, i-й операнд grep не розглядає як опцію, навіть якщо здається, що це так. Оболонка може розмістити цю змінну в середовищі для кожної команди, яку вона запускає, вказуючи, які операнди є результатами розширення підстановки імені файлу, і тому не повинні розглядатися як параметри. Ця поведінка доступна лише з бібліотекою GNU C і лише тоді, коли не встановлено POSIXLY_CORRECT.

ПРИМІТКИ

Ця довідкова сторінка підтримується лише періодично; повна документація часто є більш актуальною.

АВТОРСЬКІ ПРАВА

Авторські права належать 1998-2000, 2002, 2005-2021 Free Software Foundation, Inc.

Це безкоштовне програмне забезпечення; дивіться джерело для умов копіювання. НЕМАЄ гарантії; навіть не для ПРОДАЖУ чи ПРИГОДНОСТІ ДЛЯ КОНКРЕТНОЇ МЕТИ.

ВАДИ

Повідомлення про помилки

Надсилайте повідомлення про помилки електронною поштою на адресу на адресу повідомлення про помилки ⟨bug-grep@gnu.org⟩. An Доступні архів електронної пошти ⟨https://lists.gnu.org/mailman/listinfo/bug-grep⟩ і засіб відстеження помилок ⟨https://debbugs.gnu.org/cgi/pkgreport.cgi?package=grep

Відомі Помилки

Велика кількість повторень у конструкції {n,m} може призвести до того, що grep використовує багато пам'яті. Крім того, деякі інші незрозумілі регулярні вирази вимагають експоненційного часу та простору, і можуть призвести до того, що для grep не вистачить пам'яті.

Зворотні посилання дуже повільні і можуть вимагати експоненційного часу.

ПРИКЛАДИ

У наступному прикладі виводиться розташування та вміст будь-якого рядка, що містить “f” і закінчується на “.c”, у всіх файлах у поточному каталозі, імена яких містять “g” та закінчуються на “.h' '. Параметр -n виводить номери рядків, аргумент -- розглядає розширення “*g*.h”, починаючи з “-” як імена файлів, а не параметри, і порожній файл /dev/null призводить до виведення імен файлів, навіть якщо тільки одне ім'я файлу має вигляд “*g*.h”.


$ grep -n -- 'f.*\.c$' *g*.h /dev/null
argmatch.h:1:/* definitions and prototypes for argmatch.c

Єдиний рядок, який співпадає, це рядок 1 argmatch.h. Зауважте, що синтаксис регулярного виразу, використаний у шаблоні, відрізняється від глобального синтаксису, який використовує оболонка для відповідності імен файлів.

ДИВ. ТАКОЖ

Наступні сторінки посібника

awk(1), cmp(1), diff(1), find(1), perl(1), sed(1), sort(1), xargs(1), read(2), pcre(3), pcresyntax(3), pcrepattern(3), terminfo(5), glob(7), regex(7)

Повна документація

Доступний повний посібник ⟨https://www.gnu.org/software/grep/manual/⟩. Якщо програми info і grep правильно встановлені на вашому сайті, команда

info grep

ви зможете отримати доступ до повноцінного підручника.

ПЕРЕКЛАД

Український переклад цієї сторінки посібника виконано Olex Denkin <ks_alexandr@ukr.net>

Цей переклад є безкоштовною документацією; будь ласка, ознайомтеся з умовами GNU General Public License Version 3 ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩. НЕ НАДАЄТЬСЯ ЖОДНИХ ГАРАНТІЙ.

Якщо ви знайшли помилки у перекладі цієї сторінки підручника, будь ласка, надішліть електронний лист до списку листування перекладачів: ⟨trans-uk@lists.fedoraproject.org⟩.

2019-12-29 GNU grep 3.7