Поскольку Python 3.0 и 3.1 являются EOL'ами, и никто не использует их, вы можете и должны использовать str.format_map(mapping)
(Python 3.2 +):
По аналогии с str.format(**mapping)
, за исключением того, что сопоставление используется напрямую и не копируется в dict
.Это полезно, если, например, отображение является подклассом dict
.
Это означает, что вы можете использовать, например, defaultdict
, который установит (и вернет) значение по умолчанию для ключей, которыеотсутствуют:
>>> from collections import defaultdict
>>> vals = defaultdict(lambda: '<unset>', {'bar': 'baz'})
>>> 'foo is {foo} and bar is {bar}'.format_map(vals)
'foo is <unset> and bar is baz'
Даже если предоставленное отображение является dict
, а не подклассом, это, вероятно, все равно будет немного быстрее.
Хотя разница невелика, учитывая
>>> d = dict(foo='x', bar='y', baz='z')
, тогда
>>> 'foo is {foo}, bar is {bar} and baz is {baz}'.format_map(d)
примерно на 10 нс (2%) быстрее, чем
>>> 'foo is {foo}, bar is {bar} and baz is {baz}'.format(**d)
на моем Python 3.4.3.Разница, вероятно, будет больше, поскольку в словаре будет больше ключей, и
Обратите внимание, что язык форматирования гораздо более гибкий, чем этот;они могут содержать индексированные выражения, доступ к атрибутам и т. д., поэтому вы можете отформатировать целый объект или 2 из них:
>>> p1 = {'latitude':41.123,'longitude':71.091}
>>> p2 = {'latitude':56.456,'longitude':23.456}
>>> '{0[latitude]} {0[longitude]} - {1[latitude]} {1[longitude]}'.format(p1, p2)
'41.123 71.091 - 56.456 23.456'
Начиная с версии 3.6 вы можете использоватьИнтерполированные строки тоже:
>>> f'lat:{p1["latitude"]} lng:{p1["longitude"]}'
'lat:41.123 lng:71.091'
Вам просто нужно помнить, чтобы использовать другие символы кавычек во вложенных кавычках.Другим преимуществом этого подхода является то, что он намного быстрее, чем вызывает метод форматирования.