Integrovaná metoda format () vrací formátovanou reprezentaci dané hodnoty řízené specifikátorem formátu.
format()
Funkce je podobná metodě formátu String. Interně obě metody volají __format__()
metodu objektu.
Zatímco vestavěná format()
funkce je implementace na nízké úrovni pro formátování objektu pomocí __format__()
interně, řetězec format()
je implementace na vyšší úrovni, která umožňuje provádět složité operace formátování také na více řetězcích objektů.
Syntaxe format () je:
format (value (, format_spec))
format () Parametry
format()
Funkce má dva parametry:
- hodnota - hodnota, kterou je třeba naformátovat
- format_spec - specifikace, jak má být hodnota formátována.
Specifikátor formátu může být ve formátu:
((fill) align) (sign) (#) (0) (width) (,) (. precision) (type) where, the options are fill :: = any character align :: = "" | "=" | "^" sign :: = "+" | "-" | "" width :: = celočíselná přesnost :: = celočíselný typ :: = "b" | "c" | "d" | "e" | "E" | "f" | "F" | "g" | "G" | "n" | "o" | "s" | "x" | "X" | "%"
Na těchto odkazech se dozvíte více o typech formátů a zarovnání.
Vrátit hodnotu z format ()
format()
Funkce vrací formátovaný reprezentaci dané hodnoty stanovené ve formátu specifikátorem.
Příklad 1: Formátování čísla pomocí format ()
# d, f and b are type # integer print(format(123, "d")) # float arguments print(format(123.4567898, "f")) # binary format print(format(12, "b"))
Výstup
123 123,456790 1100
Příklad 2: Formátování čísel s výplní, zarovnáním, znaménkem, šířkou, přesností a typem
# integer print(format(1234, "*>+7,d")) # float number print(format(123.4567, "^-09.3f"))
Výstup
* + 1 234 0123,4570
Zde jsme při formátování celého čísla 1234
určili specifikátor formátování *>+7,d
. Rozumíme každé možnosti:
*
- Je to znak výplně, který po naformátování vyplní prázdná místa>
- Je to možnost zarovnání vpravo, která zarovná výstupní řetězec doprava+
- Je to volba znaménka, která vynutí číslo, které má být podepsáno (se znaménkem nalevo)7
- Je to volba šířky, která nutí číslo, aby zaujalo minimální šířku 7, ostatní mezery budou vyplněny znakem výplně,
- Je to operátor tisíců, který vkládá čárku mezi všechny tisíce.d
- Je to volba typu, která určuje, že číslo je celé číslo.
Při formátování čísla s plovoucí desetinnou čárkou 123.4567
jsme zadali specifikátor formátu ^-09.3f
. Tyto jsou:
^
- Je to možnost zarovnání na střed, která zarovná výstupní řetězec do středu zbývajícího prostoru-
- Je to volba znaménka, která vynutí zobrazení pouze záporných čísel0
- Je to znak, který je umístěn na místo prázdných mezer.9
- Možnost šířky nastavuje minimální šířku čísla na 9 (včetně desetinné čárky, tisíce čárky a znaménka).3
- Je to operátor přesnosti, který nastavuje přesnost daného plovoucího čísla na 3 místaf
- Je to volba typu, která určuje, že číslo je float.
Příklad 3: Použití format () přepsáním __format __ ()
# custom __format__() method class Person: def __format__(self, format): if(format == 'age'): return '23' return 'None' print(format(Person(), "age"))
Výstup
23
Zde jsme přepsali __format__()
metodu třídy Person
.
Nyní přijímá format
parametr a vrací 23, pokud je rovno 'age'
. Pokud není zadán žádný formát, None
je vrácen.
format()
Funkce interně pracuje Person().__format__("age")
pro návrat 23.