Анимация
JavaScript
|
Главная Библионтека функция printf- форматированный вывод Вероятно, вы захотите в большей степени контролировать выводимые данные, чем это позволяет функция print. Возможно, вы привыкли к форматированному выводу С-функции printf. Спешим обрадовать: в Perl есть почти сравнимая операция с таким же именем. Функция printf принимает список аргументов (заключенный в необязательные круглые скобки, как и в случае использования функции print). Первый аргумент - строка управления форматом, указывающая, как выводить остальные аргументы. Если вы не знакомы со стандартной функцией printf, обратитесь к man-странице print/[3) или perlfunc{\), если она у вас есть, или к главе 3 книги Programming Perl. Пример: printf "%15s %5d %10.2f\n", $s, $n, $r; Эта функция выводит $s в 15-символьном поле, затем пробел, затем $п как десятичное целое в 5-символьном поле, затем еще один пробел, затем $г как значение с плавающей запятой с двумя десятичными знаками в 10-символьном поле и, наконец, символ новой строки. Упражнения Ответы к упражнениям даны в приложении А. 1. Напишите программу, которая работает аналогично команде cat, но изменяет на обратный порядок следования всех строк всех файлов, указанных в командной строке, или всех строк, поступающих со стандартного ввода, если файлы не указаны. (В некоторых системах есть подобная утилита; она называется tac.) 2. Измените программу из предыдущего упражнения таким образом, чтобы в каждом файле, указанном в командной строке, порядок строк изменялся на обратный индивидуально. (Да-да, вы можете сделать это, пользуясь тем материалом, который до сих пор изучили, даже не возвращаясь к обзору возможностей языка Perl, приведенному в главе 1.) 3. Напишите программу, которая читает список строковых значений (каждое из которых занимает отдельную строку) и выводит эти строки в 20-символьном столбце с выравниванием справа. Например, при вводе строк hello и good-bye они выводятся в 20-символьном столбце с выравниванием справа. (Добейтесь, чтобы ваша программа действительно использовала 20-символьный столбец, а не 21-символьный. Это весьма распространенная ошибка.) 4. Измените программу из предыдущего упражнения таким образом, чтобы пользователь мог выбирать ширину столбца. Например, при вводе строк 20, hello и good-bye получатся те же результаты, что и в предыдущем упражнении, а ввод 30, hello, good-bye обеспечит размещениеhe Но и good-bye в 30-символьном столбце. в 9той таве: • Основные понятия Ш ОсноШые поправления"* испольаованЬя регулярных выражений • Образцы Еще об операции сопоставления Операция замены РвгЬ!ЛЯТЭНЫв Функции split и join • Упражнения выражения Основные понятия Регулярное выражение представляет собой образец - шаблон - который сопоставляется со строкой. Сопоставление регулярного выражения со строкой дает либо успешный результат, либо неудачный. Иногда получение того или иного результата может быть единственной целью использования регулярного выражения, а иногда ставится задача замены совпавшего образца другой строкой. Регулярные выражения используются многими программами, в частности, UNIX-командами, программами grep, sed, awk, ed, vi, emacs и даже различными shell. В каждой программе используется свой набор метасимволов (большей частью они совпадают). Perl - семантическое надмножество всех этих средств: любое регулярное выражение, которое можно записать в одной из подобных программ, может быть записано и на языке Perl, но не обязательно теми же символами. Основные направления использования регулярных выражений Если бы нам нужно было найти в каком-то файле все строки, содержащие строку аЬс, мы могли бы использовать команду гер: grep abc somefile >results в этом случае аЬс - регулярное выражение, которое команда гер сверяет с каждой входной строкой. Строки, соответствующие этому регулярному выражению, посылаются на стандартный вывод и попадают в файл results (так как в командной строке стоит оператор переадресации). В Perl мы можем превратить строку аЬс в регулярное выражение, заключив ее между косыми: if (/abc/) f print $ ; Ho что же сверяется с регулярным выражением abc в данном случае? Да наша старая подруга, переменная $! Если регулярное выражение заключено между косыми (как в этом примере), то переменная $ сверяется с регулярным выражением. Если значение переменной совпадает с регулярным выражением, операция сопоставления возвращает значение "истина". В противном случае она возвращает "ложь". В данном примере предполагается, что переменная $ содержит какую-то строку текста и выводится, если в любом месте этой строки обнаруживается последовательность символов аЬс (аналогичные действия производит приведенная выше команда .grep. Однако в отличие от grep, которая оперирует всеми строками файла, данный фрагмент Perl-программы просматривает только одну строку). Чтобы обрабатывались все строки, добавьте операцию цикла: while (О) { if (/abc/) ( print $ ; А что, если мы не знаем, сколько символов ь стоит между а и с? То есть что нужно делать, если мы хотим вывести на экран строку только в том слчае, если она содержит символ а, за которым следует ни одного или более символов Ь и символ с? Работая с grep, мы написали бы так: grep "ab*c" soir.efile >results (Аргумент, содержащий звездочку, заключен в кавычки, потому что мы не хотим, чтобы shell обработал его так, как будто это метасимвол, встретившийся в имени файла. Чтобы звездочка сработала, ее нужно передать в grep как есть.) В Perl мы можем сделать то же самое: while (О) { if (/ab*c/) { print S ; 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 [ 33 ] 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 |