python 内置类型(五)---str

4.7. Text Sequence Type — str

Python中的文本数据由str对象或strings处理。字符串是Unicode编码的不可变序列。字符串文字以各种方式写入:

  • 单引号:'允许嵌入"双"引号'
  • 双引号:"允许嵌入'单'引号"
  • 三重引号:'''三个单引号'''"""三个双引号"""

三重引用的字符串可能会跨越多行 - 所有相关的空白字符都将包含在字符串文字中。

两个字符串文字之间如果只有空格,则将被隐式转换为单个字符串文字。也就是说:

>>>'span' 'eggs'
'spaneggs'

请参阅String and Bytes literals了解更多关于各种形式的字符串的信息,包括支持的转义序列和rraw)前缀,禁用大多数转义序列处理等。

字符串也可以使用str构造函数从其他对象创建。

由于Python没有单独的character类型,索引字符串会产生长度为1的字符串。也就是说,对于非空字符串ss [0] == s [0:1]

Python也没有可变的字符串类型,但str.join()io .StringIO可用于从多个片段高效地构建字符串。

版本3.3中更改:为了向后兼容Python 2系列,字符串文字再次允许使用u前缀。它对字符串文字的含义没有影响,不能与“r”前缀组合。

class str(object='')
class str(object=b'', encoding='utf-8', errors='strict') # 针对byte-like字符串

返回object的string表示。如果未提供object,则返回空字符串。否则,str()的行为取决于是否给出encodingerrors,如下所示:

如果encodingerrors都没有给出,str(object)返回object .__ str__(),这是objectinformal或可打印的字符串表示形式。对于字符串对象,这是字符串本身。如果object没有__str__()方法,那么str ()回退到repr(object)

如果给出encodingerrors中的至少一个,object应该是bytes-like object(例如bytesbytearray)。在这种情况下,如果objectbytes(或bytearray)对象,那么str(bytes,encoding,errors)等同于bytes.decode(encoding,errors)。否则,在调用bytes.decode()之前获取缓冲区对象的字节对象。

不带参数encodingerrors的将bytes对象传递给str()属于返回informal字符串表示形式的第一种情况

>>> str(b'Zoot!')
"b'Zoot!'"

4.7.1. String Methods

字符串支持所有通用的序列方法,还支持以下所述的方法

字符串还支持两种格式的字符串格式,一种提供了很大的灵活性和定制(参见str.format()Format String SyntaxCustom String Formatting,另一种基于Cprintf样式格式处理的类型范围较窄,稍微难以正确使用,但对于可处理的情况通常更快(printf-style String Formatting)。

标准库的Text Processing Services部分涵盖了许多其他模块,它们提供了各种文本相关的工具(包括re模块中的正则表达式支持)。

str.capitalize()
返回字符串的副本: 除了第一个字符变为大写外(数字不变),其他的所有字符强制变成小写。

>>>'123aBcDeFg'.capitalize()
'123abcdefg'

str.casefold()
返回字符串的副本:Casefolded strings may be used for caseless matching.
casefold类似于lower,但更具侵略性,因为它旨在删除字符串中的所有案例区别。例如,德语小写字母ß等同于ss。由于它已经是小写字母,lower()对于ß不起作用 ;但是casefold()可以将其转换为ss

>>>'ß'.lower()
'ß'
>>>'ß'.casefold()
'ss'

Unicode标准的第3.13节描述了casefold的算法。

New in version 3.3.

str.center(width[, fillchar])
返回一个新的字符串:原本的字符串居中显示在一个长度为width的字符串中。填充是使用指定的fillchar(默认是ASCII中的空格' ')完成的。如果width小于或等于len(s),则返回原始字符串。

>>>r = '1234'
>>>r.center(10) # str.center(width)    width > len(r)
'   1234   '
>>>r.center(3) # str.center(width)   width <= len(r)
'1234'
>>>r.center(10,'.') # str.center(width, fillchar)
'...1234...'
>>>r
'1234'

str.count(sub[, start[, end]])
返回范围[start,end]中子字符串sub的非重叠次数。可选参数startend为切片符号。

str.encode(encoding="utf-8", errors="strict")
以字节对象的形式返回字符串的编码版本。默认编码是“utf-8”。 给出errors参数来设置不同的错误处理方案。 errors的默认值是'strict',这意味着编码错误会引发UnicodeError。其他可能的值是'ignore','replace','xmlcharrefreplace','backslashreplace'和通过codecs.register_error()注册的任何其他名称,请参见[Error Handlers]一节。有关可能的编码列表,请参见[Standard Encodings]部分。

# errors:
# strict    
# ignore    
# replace    
# xmlcharrefreplace    
# backslashreplace    
# 通过codecs.register_error()注册的任何其他名称
Changed in version 3.1: Support for keyword arguments added.

str.endswith(suffix[, start[, end]])
如果字符串以指定的suffix结尾,则返回True,否则返回Falsesuffix也可以是一个由后缀组成的元组。如果有start参数,则测试从start位置开始。如果有stop参数,则测试在stop位置停止

>>>r = 'abcdefgxyz'
>>>r.endswith('xyz') # 匹配到xyz
True
>>>r.endswith(('xyz', 'z')) # 使用元组,匹配到xyz
True
>>>r.endswith(('opq', 'rst','xyz'), -3, len(r))  # 使用元组,  (len(r) - 3, len(r))匹配到xyz
True
>>>r.endswith(('opq', 'rst','xyz', 'xy'), -3, len(r) - 1) # 匹配到xy
True

str.expandtabs(tabsize=8)
返回字符串的副本,其中所有制表符由一个或多个空格替换,具体取决于当前列和给定的制表符大小。tab替换出现在每个\t字符出现的位置(tabsize默认值是8)。当要展开字符串时,当前列设置为零,字符串逐个检查。如果该字符是一个制表符(\ t),则在结果中插入一个或多个空格字符(取决于设置的tabsize的大小),直到当前列等于下一个制表符位置(制表符本身不被复制).如果该字符是换行符(\ n)或返回符号(\ r),则复制该字符并将当前列重置为零。任何其他字符都将被不变地复制,而当前列增加1,无论打印时字符如何表示。

>>>'01\t012\t0123\t01234'.expandtabs()
'01      012     0123    01234'
>>> '01\t012\t0123\t01234'.expandtabs(4)
'01  012 0123    01234'

str.find(sub[, start[, end]])
返回字符串中离开头最近的索引,其中子字符串sub在切片的[start:end]内找到。可选参数startend被解释为切片符号。如果未找到sub,则返回-1

Note:
find方法只应该用于你想知道sub的位置,如果想检查sub是否存在,请使用in代替:

>>>'Py' in 'Python'
True

str.format(*args, **kwargs)
执行字符串格式化操作。调用此方法的字符串可以包含由大括号{}分隔的文本文本或替换字段。每个替换字段包含位置参数的数字索引或关键字参数的名称。返回字符串的副本,其中每个替换字段被相应参数的字符串值替换。

>>>"The sum of 1 + 2 is {0}".format(1+2)
'The sum of 1 + 2 is 3'
>>>'{a} + {b} = {sum}'.format(a=1, b=2, sum=(1 + 2))
'1 + 2 = 3'

有关可以在格式字符串中指定的各种格式选项的说明,请参见[Format String Syntax]。

Note
当使用n类型(例如{:n}'.format(1234))格式化一个数字([int],[float],[float]和其子类)时,函数将LC_CTYPE语言环境临时设置为LC_NUMERIC语言环境,以解码localeconv()decimal_pointthousands_sep字段,如果它们是非ASCII或长于1个字节,并且LC_NUMERIC语言环境不同于LC_CTYPE区域设置。此临时更改会影响其他线程。

locale 是根据计算机用户所使用的语言,所在国家或者地区,以及当地的文化传统
所定义的一个软件运行时的语言环境。通常情况下它可以按照涉及使用习惯分为12大类:
- 语言符号及其分类(LC_CTYPE)
- 数字(LC_NUMBERIC)
- 比较习惯(LC_COLLATE)
- 时间显示格式(LC_TIME)
- 货币单位(LC_MONETARY)
- 信息主要是提示信息,错误信息,状态信息,标题,标签,按钮和菜单等(LC_MESSAGES)
- 行么书写方式(LC_NAME)
- 地址书写方式(LC_ADDRESS)
- 电话号码书写方式(LC_TELEPHONE)
- 度量衡表达方式(LC_MEASUREMENT)
- 默认纸张尺寸大小(LC_PAPER)
- 对locale 自身包含信息的概述(LC_IDENTIFICATION)
- 除此之外还有一个LANGUAGE参数,它与LC_MESSAGES相似

Changed in version 3.6.5: 在使用n类型格式化数字时,函数在某些情况下会将LC_CTYPE语言环境临时设置为LC_NUMERIC类型。

str.format_map(mapping)
类似于str.format(mapping),除了直接使用mapping而不是复制到dict。例如如果mapping是一个字典子类,这是有用的:

>>>class Default(dict):
...     def __missing__(self, key):
...         return key
...
>>> '{name} was born in {country}'.format_map(Default(name='Guido'))
'Guido was born in country'

New in version 3.2.

str.index(sub[, start[, end]])
类似find(),但在未找到子字符串时引发ValueError

str.isalnum()
如果字符串中的所有字符都是字母数字且至少有一个字符,则返回true,否则返回false。如果以下其中一个返回Truec.isalpha()c.isdecimal()c.isdigit()c.isnumeric(),则字符cisalnum

str.isalpha()
如果字符串中的所有字符都是字母,并且至少有一个字符,则返回true,否则返回false。字母字符是在Unicode字符数据库中定义为“Letter”的那些字符,即具有一般类别属性是“Lm”,“Lt”,“Lu”,“Ll”或“Lo”之一的字符(参阅附录)。请注意,这与Unicode标准中定义的“字母”属性不同。

str.isdecimal()
如果字符串中的所有字符都是十进制字符,并且至少有一个字符,则返回true,否则返回false。十进制字符是那些可以用来形成基数为10的数字,例如U + 0660,阿拉伯数字0。形式上,十进制字符是Unicode常规类别“Nd”中的字符。

str.isdigit()
如果字符串中的所有字符都是数字并且至少有一个字符,则返回true,否则返回false。数字包含需要特殊处理的十进制字符和数字,例如兼容性上标数字。这包括不能用来形成基数为10的数字,如Kharosthi数字。形式上,数字是具有属性值Numeric_Type = Digit或Numeric_Type = Decimal的字符。

str.isidentifier()
如果字符串是符合语言定义的有效标识符,则返回true. 标识符和关键字

使用keyword.iskeyword()来测试保留的标识符,如defclass

str.islower()
如果字符串中的所有cased字符都是小写字母,并且至少有一个cased字符,则返回true,否则返回false。

str.isnumeric()
如果字符串中的所有字符都是数字字符,并且至少有一个字符,则返回true,否则返回false。数字字符包括digit字符和具有Unicode数字值属性的所有字符,例如U + 2155,VULGAR分数ONE FIFTH。形式上,数字字符是具有属性值Numeric_Type = Digit,Numeric_Type = Decimal或Numeric_Type = Numeric的字符。

str.isprintable()
如果字符串中的所有字符都可打印或字符串为空,则返回true,否则返回false。非可打印字符是在Unicode字符数据库中定义为“Other”或“Separator”的字符,但ASCII空格(0x20)被认为是可打印的。 (注意,在这个上下文中的可打印字符是那些在字符串上调用repr()时不应该被转义的字符,它不会影响写入sys.stdoutsys.stderr)。

str.isspace()
如果字符串中只有空格字符,并且至少有一个字符,则返回true,否则返回false。空格字符是在Unicode字符数据库中定义为“Other”或“Separator”的那些字符,以及具有“WS”,“B”或“S”之一的双向属性的那些字符。

str.istitle()
如果字符串是一个标题字符串,并且至少有一个字符,则返回true,例如,大写字符只能跟在uncased字符之后,而小写字符只能在一个cased字符之后。否则返回false。

str.isupper()
如果字符串中的所有cased字符都是大写且至少有一个cased字符,则返回true,否则返回false。

str.join(iterable)
返回一个字符串,它是iterable中字符串的串联。如果iterable中有任何非字符串值,包括bytes对象,则会引发TypeError`。元素之间的分隔符是提供此方法的字符串。

str.ljust(width[, fillchar])
返回一个新的字符串。如果width<=len(str),则字符串不变,否则将字符串左对齐,并且在后面填充fillchar(默认是ASCII的空格).

str.lower()
返回字符串的一个副本,并将所有字符转换为小写字母。

str.lstrip([chars])
返回删除前导字符的字符串的副本。 chars参数是一个字符串,指定要删除的字符集。如果省略或者Nonechars参数默认删除空格。 chars参数不是一个前缀;相反,它的值的所有组合都被剥离了:

>>> '   spacious   '.lstrip()
'spacious   '
>>> 'www.example.com'.lstrip('cmowz.')
'example.com'

static str.maketrans(x[, y[, z]])
这个静态方法返回一个可用于str.translate()的转换表

如果只有一个参数,它必须是一个将Unicode序数(整数)或字符(长度为1的字符串)映射到Unicode序号,字符串(任意长度)或None的字典。字符键将被转换为序号。
如果有两个参数,它们必须是长度相等的字符串,并且在结果字典中,x中的每个字符将映射到y中相同位置的字符。
如果有第三个参数,它必须是一个字符串,其字符将被映射到结果中的None

>>>l = '123qwe'
>>>l.maketrans({'1':'2'})
{49: '2'}
>>>l.maketrans('123','456')
{49: 52, 50: 53, 51: 54}
>>>l.maketrans('123','456', 'qwe')
{49: 52, 50: 53, 51: 54, 113: None, 119: None, 101: None}

str.partition(sep)
sep的第一个出现处拆分字符串,并返回包含分隔符之前的部分,分隔符本身和分隔符之后的部分的三元组。如果找不到分隔符,则返回包含字符串本身及两个空字符串的三元组。

>>>l.partition('3')
('12', '3', 'qwe')
>>>l.partition('0')
('123qwe', '', '')
>>>l.partition('234')
('123qwe', '', '')
>>>l.partition('23')
('1', '23', 'qwe')

str.replace(old, new[, count])返回所有出现的子字符串old替换为new的字符串的副本。如果给出可选参数count,则只会替换count`次数。

>>>l = 'youyouyouyou'
>>>l.replace('y', 'r', 2)
'rourouyouyou'

str.rfind(sub[, start[, end]])
返回找到substring sub的字符串中的最高索引,使得sub包含在s [start:end]内。可选参数startend被解释为切片符号。当失败时返回-1
对比find方法,此方法为从后往前查找(rfind-->right find)

str.rindex(sub[, start[, end]])
rfind()一样,但是在找不到子字符串sub时引发ValueError
对比index方法,此方法为从后往前查找(rindex-->right index)

str.rjust(width[, fillchar])
返回字符串右对齐的长度为width的字符串。填充是使用指定的fillchar(默认是ASCII中的空格)完成的。如果width小于或等于len(s),则返回原始字符串。
对比ljust方法,此方法为右对齐。

str.rpartition(sep)
sep的最后出现处拆分字符串,并返回包含分隔符之前的部分,分隔符本身和分隔符之后的部分的三元组。如果未找到分隔符,则返回包含两个空字符串的三元组,然后返回字符串本身。
对比partition方法,rpartition从右到左遍历。

str.rsplit(sep=None, maxsplit=-1)
返回字符串中的单词列表,使用sep作为分隔符字符串。如果给出maxsplit,最多分割maxsplit次,此方法从最右边开始分割。如果sep没有指定或者没有,则任何空格字符串都是分隔符。除了从右边分割外,[rsplit()]的行为就像[split()],这在下面详细描述。

str.rstrip([chars])
返回删除了尾随字符的字符串的副本。 chars参数是一个字符串,指定要删除的字符集。如果省略或者Nonechars参数默认删除空格。 chars参数不是后缀;相反,其值的所有组合都被剥离:

>>> '   spacious   '.rstrip()
'   spacious'
>>> 'mississippi'.rstrip('ipz')
'mississ'

str.split(sep=None, maxsplit=-1)
返回字符串中的单词列表,使用sep作为分隔符字符串。如果给出maxsplit,最多分割maxsplit次(因此,该列表最多只有maxsplit + 1个元素)。如果maxsplit没有被指定或者是-1,那么分割的数量是没有限制的(返回所有可能的分割)。

如果给定sep,则分割时连续的分隔符不会被分组在一起,并被视为分隔空字符串(例如'1,2'.split(',')返回['1','','' 2' ])。 sep参数可以由多个字符组成(例如,'1<>2<>3'.split('<>')返回['1','2','3']) 。用指定的分隔符分割空字符串会返回['']

For example:

>>>'1,2,3'.split(',')
['1', '2', '3']
>>> '1,2,3'.split(',', maxsplit=1)
['1', '2,3']
>>> '1,2,,3,'.split(',')
['1', '2', '', '3', '']

如果未指定* sep *或者为None,则应用不同的分割算法:将连续空白的运行视为单个分隔符,并且如果该字符串具有前导或结果,则在开始或结束时不会包含空字符串或拖尾的空白。因此,将一个空字符串或一个只包含空格的字符串与一个“None”分隔符分开将返回[]

For example:

>>>'1 2 3'.split()
['1', '2', '3']
>>> '1 2 3'.split(maxsplit=1)
['1', '2 3']
>>> '   1   2   3   '.split()
['1', '2', '3']

str.splitlines([keepends])
返回字符串中lines的列表,在lines边界处突破。换行符不包含在结果列表中,除非* keepends *被给出且为真。
此方法分割在以下行边界上。特别是,边界是universal newlines的超集:

Representation Description
\n Line Feed
\r Carriage Return
\r\n Carriage Return + Line Feed
\v or \x0b Line Tabulation
\f or \x0c Form Feed
\x1c File Separator
\x1d Group Separator
\x1e Record Separator
\x85 Next Line (C1 Control Code)
\u2028 Line Separator
\u2029 Paragraph Separator

Changed in version 3.2:将\v\f添加到行边界列表中。

For example:

>>> 'ab c\n\nde fg\rkl\r\n'.splitlines()
['ab c', '', 'de fg', 'kl']
>>> 'ab c\n\nde fg\rkl\r\n'.splitlines(keepends=True)
['ab c\n', '\n', 'de fg\r', 'kl\r\n']

Unlike [split()] when a delimiter string sep is given, this method returns an empty list for the empty string, and a terminal line break does not result in an extra line:
与[split()]不同,此方法返回空字符串的空列表,并且终端行分隔不会导致多余行:

>>>"".splitlines()
[]
>>> "One line\n".splitlines()
['One line']

For comparison, split('\n') gives:

>>>''.split('\n')
['']
>>> 'Two lines\n'.split('\n')
['Two lines', '']

str.startswith(prefix[, start[, end]])
如果字符串以prefix开头,则返回True,否则返回Falseprefix也可以是一个前缀元组来查找。使用可选的start,测试字符串从该位置开始。使用可选的end,停止在该位置比较字符串。
类比endswith.

str.strip([chars])
返回删除前导字符和尾随字符的字符串副本。 * chars 参数是一个字符串,指定要删除的字符集。如果省略或者None chars *参数默认删除空格。 * chars *参数不是前缀或后缀;相反,其值的所有组合都被剥离:

>>>'   spacious   '.strip()
'spacious'
>>> 'www.example.com'.strip('cmowz.')
'example'

从字符串中剥离最外部的前导和尾部chars参数值。从前端删除字符,直到到达chars中字符集中不包含的字符串字符。尾端发生类似的行为。例如:

>>>comment_string = '#....... Section 3.2.1 Issue #32 .......'
>>> comment_string.strip('.#! ')
'Section 3.2.1 Issue #32'

str.swapcase()
返回大写字符转换为小写字符串的副本,反之亦然。请注意,s.swapcase().swapcase()== s不一定成立。

str.title()
返回字符串的字幕版本,其中字以大写字符开头,其余字符为小写字母。
For example:

>>> 'Hello world'.title()
'Hello World'

该算法使用简单的与语言无关的单词定义作为连续字母组。这个定义在很多情况下都有效,但是这意味着收缩和占有者的撇号(')形成了单词边界,这可能不是理想的结果:

>>>"they're bill's friends from the UK".title()
"They'Re Bill'S Friends From The Uk"

可以使用正则表达式构造撇号的解决方法:

>>> import re
>>> def titlecase(s):
...     return re.sub(r"[A-Za-z]+('[A-Za-z]+)?",
...                   lambda mo: mo.group(0)[0].upper() +
...                              mo.group(0)[1:].lower(),
...                   s)
...
>>> titlecase("they're bill's friends.")
"They're Bill's Friends."

str.translate(table)
通过给定的转换表返回每个字符已映射的字符串的副本。该表必须是通过__getitem __()实现索引的对象,通常是mappingsequence。当通过Unicode序数(整数)索引时,表对象可以执行以下任何操作:返回Unicode序号或字符串,将字符映射到一个或多个其他字符;返回None,从返回字符串中删除字符;或引发LookupError异常,将字符映射到自身。

你可以使用[str.maketrans()]来创建不同格式的字符到字符映射的转换映射。

另请参阅codecs模块,以获得更灵活的自定义字符映射方法。

str.upper()
返回字符串的所有字符转换为大写的副本。请注意,如果s包含uncased字符,或者如果生成的字符的Unicode类别不是“Lu”(Letter,大写),则str.upper().isupper()可能是False。比如: “Lt”(Letter,titlecase)。

Unicode标准的第3.13节描述了The uppercasing algorithm.

str.zfill(width)
返回一个左边填充了ASCII0数字的字符串的副本,以产生一个长度为width的字符串。 前导符号前缀('+'/`` - ')是通过在符号字符之后插入填充符*而不是之前处理的。 如果width小于或等于len(s)`,则返回原始字符串
For example:

>>>"42".zfill(5)
'00042'
>>> "-42".zfill(5)
'-0042'

4.7.2. printf-style String Formatting

Note

The formatting operations described here exhibit a variety of quirks that lead to a number of common errors (such as failing to display tuples and dictionaries correctly). Using the newer [formatted string literals] or the [str.format()] interface helps avoid these errors. These alternatives also provide more powerful, flexible and extensible approaches to formatting text.
这里描述的格式化操作表现出各种各样的怪癖,导致许多常见错误(如未能正确显示元组和字典)。使用新的formatted string literalsstr.format()接口有助于避免这些错误。这些替代方案还提供了更强大,灵活和可扩展的方法来格式化文本。

字符串对象有一个独特的内置操作:操作符(模)。这也被称为字符串* formatting interpolation 运算符。给定format%values(其中 format 是一个字符串), format 中的转换规范被替换为 values *的零个或多个元素。其效果与在C语言中使用sprintf()类似。

If format requires a single argument, values may be a single non-tuple object. [[5]]] Otherwise, values must be a tuple with exactly the number of items specified by the format string, or a single mapping object (for example, a dictionary).

A conversion specifier contains two or more characters and has the following components, which must occur in this order:

  1. The '%' character, which marks the start of the specifier.
  2. Mapping key (optional), consisting of a parenthesised sequence of characters (for example, (somename)).
  3. Conversion flags (optional), which affect the result of some conversion types.
  4. Minimum field width (optional). If specified as an '*' (asterisk), the actual width is read from the next element of the tuple in values, and the object to convert comes after the minimum field width and optional precision.
  5. Precision (optional), given as a '.' (dot) followed by the precision. If specified as '*' (an asterisk), the actual precision is read from the next element of the tuple in values, and the value to convert comes after the precision.
  6. Length modifier (optional).
  7. Conversion type.

When the right argument is a dictionary (or other mapping type), then the formats in the string must include a parenthesised mapping key into that dictionary inserted immediately after the '%' character. The mapping key selects the value to be formatted from the mapping. For example:

>>>print('%(language)s has %(number)03d quote types.' %
...       {'language': "Python", "number": 2})
Python has 002 quote types.

In this case no * specifiers may occur in a format (since they require a sequential parameter list).

The conversion flag characters are:

Flag Meaning
'#' The value conversion will use the “alternate form” (where defined below).
'0' The conversion will be zero padded for numeric values.
'-' The converted value is left adjusted (overrides the '0' conversion if both are given).
' ' (a space) A blank should be left before a positive number (or empty string) produced by a signed conversion.
'+' A sign character ('+' or '-') will precede the conversion (overrides a “space” flag).

A length modifier (h, l, or L) may be present, but is ignored as it is not necessary for Python – so e.g. %ld is identical to %d.

The conversion types are:

Conversion Meaning Notes
'd' Signed integer decimal.
'i' Signed integer decimal.
'o' Signed octal value. (1)
'u' Obsolete type – it is identical to 'd'. (6)
'x' Signed hexadecimal (lowercase). (2)
'X' Signed hexadecimal (uppercase). (2)
'e' Floating point exponential format (lowercase). (3)
'E' Floating point exponential format (uppercase). (3)
'f' Floating point decimal format. (3)
'F' Floating point decimal format. (3)
'g' Floating point format. Uses lowercase exponential format if exponent is less than -4 or not less than precision, decimal format otherwise. (4)
'G' Floating point format. Uses uppercase exponential format if exponent is less than -4 or not less than precision, decimal format otherwise. (4)
'c' Single character (accepts integer or single character string).
'r' String (converts any Python object using repr()). (5)
's' String (converts any Python object using str()). (5)
'a' String (converts any Python object using ascii()). (5)
'%' No argument is converted, results in a '%' character in the result.

Notes:

  1. The alternate form causes a leading octal specifier ('0o') to be inserted before the first digit.

  2. The alternate form causes a leading '0x' or '0X' (depending on whether the 'x' or 'X' format was used) to be inserted before the first digit.

  3. The alternate form causes the result to always contain a decimal point, even if no digits follow it.

    The precision determines the number of digits after the decimal point and defaults to 6.

  4. The alternate form causes the result to always contain a decimal point, and trailing zeroes are not removed as they would otherwise be.

    The precision determines the number of significant digits before and after the decimal point and defaults to 6.

  5. If precision is N, the output is truncated to N characters.

  6. See PEP 237.

Since Python strings have an explicit length, %s conversions do not assume that '\0' is the end of the string.

Changed in version 3.1: %f conversions for numbers whose absolute value is over 1e50 are no longer replaced by %g conversions.

附录:

Unicode常规类别
类别 说明
Lu 字母,大写
Ll 字母,小写
Lt 字母,词首字母大写
Lm 字母,修饰符
Lo 字母,其他
Mn 标记,非间距
Mc 标记,间距组合
Me 标记,封闭
Nd 数字,十进制数
Nl 数字,字母
No 数字,其他
Pc 标点,连接符
Pd 标点,短划线
Ps 标点,开始
Pe 标点,结束
Pi 标点,前引号(根据用途可能表现为类似 Ps 或 Pe)
Pf 标点,后引号(根据用途可能表现为类似 Ps 或 Pe)
Po 标点,其他
Sm 符号,数学
Sc 符号,货币
Sk 符号,修饰符
So 符号,其他
Zs 分隔符,空白
Zl 分隔符,行
Zp 分隔符,段落
Cc 其他,控制
Cf 其他,格式
Cs 其他,代理项
Co 其他,私用
Cn 其他,未赋值(不存在任何字符具有此属性)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,355评论 0 23
  • 4.8. Binary Sequence Types — bytes, bytearray, memoryview...
    xpf2000阅读 4,925评论 0 1
  • 前些天心血来潮想喝牛奶,到超市后发现种类繁多,不知如何下手,于是选了常出现在电视和视频广告里的那个经典,然后高...
    细雨无痕阅读 324评论 0 0
  • 不经意间,身边的人一个个都抱起来了孩子,一个个朋友在朋友圈秀着恩爱,身边的长辈、朋友开始催着你结婚,逢年过节...
    求为阅读 405评论 1 1
  • 爱别离 恨离离 对酒当歌 人生几何 痛到深处 大声呼喊 只剩嘶哑 情到深处 方知酒浓 一切已晚 寂静夜晚 心已沉重...
    罗瑛敦阅读 211评论 4 10