Karena Python 3.0 dan 3.1 EOL'ed dan tidak ada yang menggunakannya, Anda dapat dan harus menggunakan str.format_map(mapping)
(Python 3.2+):
Mirip dengan str.format(**mapping)
, kecuali bahwa pemetaan digunakan secara langsung dan tidak disalin kedict
. Ini berguna jika misalnya pemetaan adalah dict
subkelas.
Apa artinya ini adalah bahwa Anda dapat menggunakan misalnya a defaultdict
yang akan menetapkan (dan mengembalikan) nilai default untuk kunci yang hilang:
>>> 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'
Bahkan jika pemetaan yang disediakan adalah a dict
, bukan subclass, ini mungkin masih akan sedikit lebih cepat.
Perbedaannya tidak besar, mengingat
>>> d = dict(foo='x', bar='y', baz='z')
kemudian
>>> 'foo is {foo}, bar is {bar} and baz is {baz}'.format_map(d)
sekitar 10 ns (2%) lebih cepat dari
>>> 'foo is {foo}, bar is {bar} and baz is {baz}'.format(**d)
pada Python 3.4.3 saya. Perbedaannya mungkin akan lebih besar karena lebih banyak kunci dalam kamus, dan
Perhatikan bahwa bahasa format jauh lebih fleksibel daripada itu; mereka dapat berisi ekspresi yang diindeks, akses atribut dan sebagainya, sehingga Anda dapat memformat seluruh objek, atau 2 di antaranya:
>>> 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'
Mulai dari 3,6 Anda dapat menggunakan string interpolasi juga:
>>> f'lat:{p1["latitude"]} lng:{p1["longitude"]}'
'lat:41.123 lng:71.091'
Anda hanya perlu ingat untuk menggunakan karakter kutipan lain dalam tanda kutip bersarang. Kelebihan lain dari pendekatan ini adalah bahwa itu jauh lebih cepat daripada memanggil metode pemformatan.