Вы можете добавить другие значения между % и определением типа, чтобы указать минимальную и максимальную ширину, выравнивание и заполнение символами.
Определим несколько переменных: целочисленную n, число с плавающей точкой f и строку s:
>>>> n = 42
>>>> f = 7.03
>>>> s = 'string cheese'
Отформатируем их, используя ширину по умолчанию:
>>>> '%d %f %s' % (n, f, s)
>'42 7.030000 string cheese'
Установим минимальную длину поля, равную 10 символам, для каждой переменной и выровняем их по правому краю, заполняя неиспользованное место пробелами:
>>>> '%10d %10f %10s' % (n, f, s)
>'········42···7.030000 string cheese'
Используем ту же ширину поля, но выравнивание будет по левому краю:
>>>> '%-10d %-10f %-10s' % (n, f, s)
>'42·········7.030000···string cheese'
В этот раз укажем ту же длину поля, но максимальное количество символов будет равно 4, выровняем все по правому краю. Такая настройка обрезает строку и ограничивает число с плавающей точкой четырьмя цифрами после десятичной запятой:
>>>> '%10.4d %10.4f %10.4s' % (n, f, s)
>'······0042·····7.0300·······stri'
То же самое, но выравнивание по правому краю:
>>>> '%.4d %.4f %.4s' % (n, f, s)
>'0042 7.0300 stri'
Наконец, получим длину полей из аргументов, вместо того чтобы жестко ее закодировать:
>>>> '%*.*d %*.*f %*.*s' % (10, 4, n, 10, 4, f, 10, 4, s)
>'······0042·····7.0300·······stri'
Новый стиль форматирования с помощью символов {} и функции format
Старый стиль форматирования все еще поддерживается. В Python 2, который остановился на версии 2.7, он будет поддерживаться всегда. Но если вы работаете с Python 3, рекомендуется применять новый стиль форматирования.
Простейший пример его использования показан здесь:
>>>> '{} {} {}'.format(n, f, s)
>'42 7.03 string cheese'
Аргументы старого стиля нужно предоставлять в порядке появления их заполнителей с символами % в оригинальной строке. С помощью нового стиля вы можете указывать любой порядок:
>>>> '{2} {0} {1}'.format(f, s, n)
>'42 7.03 string cheese'
Значение 0 относится к первому аргументу, f, 1 относится к строке s, а 2 — к последнему аргументу, целому числу n.
Аргументы могут являться словарем или именованными аргументами, а спецификаторы могут включать их имена:
>>>> '{n} {f} {s}'.format(n=42, f=7.03, s='string cheese')
>'42 7.03 string cheese'
В следующем примере попробуем объединить три наших значения в словарь, который выглядит так:
>>>> d = {'n': 42, 'f': 7.03, 's': 'string cheese'}
В следующем примере {0} подразумевает весь словарь, а {1} — строку 'other', которая следует за словарем:
>>>> '{0[n]} {0[f]} {0[s]} {1}'.format(d, 'other')