Создание команды uniq
явилось стимулом для введения флага -u
в команде sort
: флаг отбрасывает все строки, кроме одной, из группы соседних повторяющихся строк. Выведение отдельной программы для этой операции позволяет выполнять ее независимо от сортировки. Например, uniq
удалит повторяющиеся пустые строки, независимо от того, сортируется входной поток или нет. Флаги предусматривают специальные способы обработки повторяющихся строк: uniq -d
печатает только повторяющиеся строки, uniq -u
— только уникальные, т.е. неповторяющиеся строки; uniq -c
подсчитывает число вхождений каждой строки, в чем вскоре вы убедитесь на примере.
Программа comm
служит для сравнения файлов. Получив два отсортированных входных файла f1
и f2
, она выдает выходной поток в три столбца: строки, встречающиеся только в f1
, строки, встречающиеся только в f2
, и строки, встречающиеся в обоих файлах. С помощью флага можно убрать любой из этих столбцов:
$ comm -12 f1 f2
выдает только строки, содержащиеся в обоих файлах, а
$ comm -23 f1 f2
выдает строки, которые есть только в первом, но не во втором файле. Это удобно для сравнения каталогов и списка слов со словарем.
Команда tr
проводит транслитерацию символов своего входного потока. Наиболее часто они используются для преобразования строчных букв в прописные и обратно:
$ tr a-z A-Z
Перевести строчные буквы в прописные
$ tr A-Z a-z
Перевести прописные буквы в строчные
Несколько отличается от всех рассмотренных выше команд dd
. Эта команда предназначена прежде всего для обработки данных на магнитной ленте, полученных из других систем — само ее название служит напоминанием о языке управлений заданиями OS/360. Команда dd
выполняет преобразование прописных букв в строчные, и наоборот (в нотации, отличной от нотации команды tr
). Она осуществляет перевод из множества символов ASCII в EBCDIC, и наоборот; может читать и писать данные в формате записей фиксированного размера с дополнением пробелами, что характерно для отличных от UNIX систем. На практике команду dd
часто используют для работы с исходными неотформатированными данными, откуда бы они ни были получены; она реализует набор средств для работы с двоичными данными.
Посмотрим, чего можно достичь с помощью взаимодействия фильтров на примере конвейера, который печатает 10 наиболее часто встречающихся во входном потоке слов:
cat $* |
tr -sc A-Za-z '\012' |
Сжимаем все небуквы в перевод строки
sort |
uniq -с |
sort -n |
tail |
5
Команда cat
собирает файлы, поскольку tr
может читать только стандартный входной поток. Команда tr
действует, как указано в справочном руководстве: она сжимает соседние, отличные от букв, символы в символы перевода строк, преобразуя таким образом входной поток в строки из одного слова. Затем слова сортируются и с помощью uniq -с
каждая группа идентичных слов сжимается в одну строку, начинающуюся со счетчика, который используется как сортируемое поле в команде sort -n
. (Эта последовательность двух команд сортировки, между которыми находится команда uniq, применяется так часто, что уже стала идиомой.) В результате получаются неповторяющиеся слова, отсортированные в порядке возрастания частоты появления в документе. Команда tail
отбирает 10 наиболее часто встречающихся слов (т.е. конец отсортированного файла) и команда 5
печатает их в пять столбцов.
Заметьте, кстати, что введение символа |
в конце строки — это законный способ ее продолжения.
Упражнение 4.3
Используя средства этого раздела и файл /usr/dict/words
, составьте простой анализатор правильности написания текста на английском языке. Каковы его недостатки и как их исправить?
Упражнение 4.4
Напишите программу подсчета слов на предпочитаемом вами языке программирования. Сравните ее размер, скорость и самодокументированность с соответствующим конвейером. Насколько легко вы можете преобразовать эту программу в программу проверки правильности написания текста?
4.3 Потоковый редактор sed
Вернемся теперь к редактору sed
. Поскольку он происходит непосредственно от ed
, вы легко изучите его и закрепите свои знания о редакторе ed
. Основа редактора sed
проста:
$ sed 'список команда ed' имена_файлов...
Читать дальше
Конец ознакомительного отрывка
Купить книгу