Есть один момент, который отличает старый стиль от нового: значение точности
(после десятичной запятой) все еще означает количество цифр после десятичной
192
Глава 7. Работаем с данными профессионально
запятой для дробных чисел и максимальное число символов строки, но вы не мо-
жете использовать его для целых чисел:
>>> '{0:>10.4d} {1:>10.4f} {2:10.4s}'.format(n, f, s)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: Precision not allowed in integer format specifier
>>> '{0:>10d} {1:>10.4f} {2:>10.4s}'.format(n, f, s)
' 42 7.0300 stri'
Последняя опция — это символ-заполнитель. Если вы хотите заполнить поле
вывода чем-то кроме пробелов, разместите этот символ сразу после двоеточия, но
перед символами выравнивания (<, >, ^) или спецификатором ширины:
>>> '{0:!^20s}'.format('BIG SALE')
'!!!!!!BIG SALE!!!!!!'
Совпадение с регулярными выражениями
В главе 2 немного рассматривались операции со строками. Вооружившись этой
промежуточной информацией, вы, возможно, использовали простые шаблоны
в командной строке, содержащие символ подстановки, вроде ls *.py, что означает
«перечислить все имена файлов, заканчивающиеся на .py».
Пришло время рассмотреть более сложный механизм проверки на совпадение
с шаблоном — регулярные выражения. Этот механизм поставляется в стандартном
модуле re, который мы импортируем. Вы определяете строковый шаблон, совпаде-
ния для которого вам нужно найти, и строку- источник, в которой следует вы-
полнить поиск. Простой пример использования выглядит так:
result = re.match('You', 'Young Frankenstein')
В этом примере строка 'You' является шаблоном, а 'Young Frankenstein' — ис-
точником, строкой, которую вы хотите проверить. Функция match() проверяет,
начинается ли источник с шаблона.
Для более сложных проверок вам нужно скомпилировать шаблон, чтобы уско-
рить поиск:
youpattern = re.compile('You')
Далее вы можете выполнить проверку с помощью скомпилированного шаблона:
result = youpattern.match('Young Frankenstein')
Функция match() — это не единственный способ сравнить шаблон и источник,
существует еще несколько методов.
search() возвращает первое совпадение, если таковое имеется.
findall() возвращает список всех непересекающихся совпадений, если таковые
имеются.
Текстовые строки
193
split() разбивает источник на совпадения с шаблоном и возвращает список всех
фрагментов строки.
sub() принимает аргумент для замены и заменяет все части источника, совпа-
вшие с шаблоном, на значение этого аргумента.
Точное совпадение с помощью функции match()
Начинается ли строка 'Young Frankenstein' со слова 'You'? Рассмотрим пример кода