PYT Format Syntax
PYT Format Syntax
PYT Format Syntax
The str.format() method and the Formatter class share the same syntax for format
strings (although in the case of Formatter, subclasses can define their own for
mat string syntax).
Format strings contain replacement fields surrounded by curly braces {}. Anything
that is not contained in braces is considered literal text, which is copied unch
anged to the output. If you need to include a brace character in the literal tex
t, it can be escaped by doubling: {{ and }}.
The grammar for a replacement field is as follows:
replacement_field ::= "{" [field_name] ["!" conversion] [":" format_spec] "}"
field_name
::= arg_name ("." attribute_name | "[" element_index "]")*
arg_name
::= [identifier | integer]
attribute_name
::= identifier
element_index
::= integer | index_string
index_string
::= <any source character except "]"> +
conversion
::= "r" | "s"
format_spec
::= <described in the next section>
In less formal terms, the replacement field can start with a field_name that spe
cifies the object whose value is to be formatted and inserted into the output in
stead of the replacement field. The field_name is optionally followed by a conve
rsion field, which is preceded by an exclamation point '!', and a format_spec, w
hich is preceded by a colon ':'. These specify a non-default format for the repl
acement value.
See also the Format Specification Mini-Language section.
The field_name itself begins with an arg_name that is either a number or a keywo
rd. If it s a number, it refers to a positional argument, and if it s a keyword, it
refers to a named keyword argument. If the numerical arg_names in a format strin
g are 0, 1, 2, ... in sequence, they can all be omitted (not just some) and the
numbers 0, 1, 2, ... will be automatically inserted in that order. Because arg_n
ame is not quote-delimited, it is not possible to specify arbitrary dictionary k
eys (e.g., the strings '10' or ':-]') within a format string. The arg_name can b
e followed by any number of index or attribute expressions. An expression of the
form '.name' selects the named attribute using getattr(), while an expression o
f the form '[index]' does an index lookup using __getitem__().
Changed in version 2.7: The positional argument specifiers can be omitted, so '{
} {}' is equivalent to '{0} {1}'.
Some simple format string examples:
"First, thou shalt count to {0}" # References first positional argument
"Bring me a {}"
# Implicitly references the first positional ar
gument
"From {} to {}"
# Same as "From {0} to {1}"
"My quest is {name}"
# References keyword argument 'name'
"Weight in tons {0.weight}"
# 'weight' attribute of first positional arg
"Units destroyed: {players[0]}" # First element of keyword argument 'players'.
The conversion field causes a type coercion before formatting. Normally, the job
of formatting a value is done by the __format__() method of the value itself. H
owever, in some cases it is desirable to force a type to be formatted as a strin
g, overriding its own definition of formatting. By converting the value to a str
ing before calling __format__(), the normal formatting logic is bypassed.
Two conversion flags are currently supported: '!s' which calls str() on the valu
e, and '!r' which calls repr().
Some examples:
"Harold's a clever {0!s}"
# Calls str() on the argument first
"Bring out the holy {name!r}"
# Calls repr() on the argument first
The format_spec field contains a specification of how the value should be presen
ted, including such details as field width, alignment, padding, decimal precisio
n and so on. Each value type can define its own formatting mini-language or interp
retation of the format_spec.
Most built-in types support a common formatting mini-language, which is describe
d in the next section.
A format_spec field can also include nested replacement fields within it. These
nested replacement fields can contain only a field name; conversion flags and fo
rmat specifications are not allowed. The replacement fields within the format_sp
ec are substituted before the format_spec string is interpreted. This allows the
formatting of a value to be dynamically specified.