python学习——字符串

所有的标准序列操作都是用于字符串,但是字符串是不可变的,因此所有的元素赋值和切片赋值都是非法的。

一、设置字符串的格式

# 设置字符串的格式
# 只写两种
# 1、使用元组
a = "Hello, %s. %s enough for ya?"
values = ('world', 'Hot')
print(a % values)
# 2、使用模板字符串
tmpl = Template("Hello, $who! $what enough for ya?")
print(tmpl.substitute(who='Mars', what='Dusty'))

二、替换字段

这里主要是对字符串调用方法format,并提供要设置其格式的值。
字符串包含有关如何设置格式的信息,而这些信息是使用一种微型格式指定语言(mini-language)指定的。
每个值都被插入字符串中,以替代用花括号括起的**替换字段**。要在最终结果中包含花括号,可在格式字符串中使用两个花括号({{或}})来指定。

替换字段包含:

  • 字段名:索引或标识符,指出要设置哪个值的格式并使用结果来替换该字段。
  • 转换标识:跟在叹号后面的单个字符。当前支持的字符包括r(repr)、s(str)、a(ascii)
  • 格式说明符:跟在冒号后面的表达式。格式说明符让我们能够详细地指定最终的格式,包括格式类型、字段精度和数的精度,如何显示符号和千位分隔符,以及各种对齐和填充方式。

2.1替换字段名
最简单的情况下,只需向format提供要设置其格式的未命名参数,并在格式字符串中使用未命名字段。

# 替换字段名
print("{foo} {} {bar} {}".format(1, 2, bar=4, foo=3))
# 还可以通过索引来指定在哪个字段中使用相应的未命名参数
# 这样可不按顺序使用未命名参数。
print("{foo} {1} {bar} {0}".format(1, 2, bar=4, foo=3))
# ---------------
# 3 1 4 2
# 3 2 4 1

2.2基本转换
指定要在字段中包含的值后,就可添加有关如何设置其格式的指令。

# 基本转换
# !类型说明符 是转换标识
print("{pi!s}  {pi!r}  {pi!a}".format(pi="Π"))
# ---------------
# Π  'Π'  '\u03a0'
                            字符串格式设置中的类型说明符
类型 含 义
b 将整数表示为二进制
c 将整数解读为Unicode码点
d 将整数视为十进制数进行处理,这是整数默认使用的说明符
e 使用科学表示法来表示小数(用e来表示指数)
E 与e相同,用E来表示指数
f 将小数表示为定点数,但对于特殊值(nan和inf),用大写表示
g 自动在定点表示法和科学标识法之间做出选择。这是默认用于小数的说明符。
G 与g相同,但使用大写来表示指数与特殊值
n 与g相同,但插入随区域而异的数字分隔符
o 将整数表示为八进制数
s 保持字符串的格式不变,这是默认用于字符串的说明符
x 将整数表示为十六进制并使用小写字母
% 将数表示为百分比值(乘以100,按说明符f设置格式,再在后面加上%)

2.3宽度、精度和千位分隔符
设置浮点数的格式时,默认在小数点后面显示6位小数,并根据需要设置字段的宽度,而不进行任何形式的填充。

# 宽度
print("{num:10}".format(num=3))
print("{num:10}".format(num="Bob"))
# ---------------
# '        3'
# 'Bob      '

# 精度,需要在它前面加上一个表示小数点的句点
print("{pi:.2f}".format(pi=3.1415926))
# ---------------
# 3.14

# 千位分隔符,使用逗号
print('One googol is {:,}'.format(10**100))
# ---------------
# One googol is 10,000,000,000,000,
# 000,000,000,000,000,000,000,000,
# 000,000,000,000,000,000,000,000,
# 000,000,000,000,000,000,000,000,
# 000,000,000,000,000

2.4符号、对齐和用0填充

三、字符串方法

# 字符串方法
s = "hello world"
# 1、方法center,在两边添加填充字符让字符串居中
print("center:", s.center(20, "*"))

# 2、方法find,在字符串中查找子串,返回子串的第一个字符的索引
print("find:", s.find('hello'))  # 也可以指定起点和终点s.find("**", 10, 20)

# 3、方法join,与split相反,用于合并序列的元素
seq = ['1', '2', '3', '4']
sep = "+"
print("join:", sep.join(seq))

# 4、方法split,用于将字符串拆分成序列
spl = '/usr/bin/env'
print("split:", spl.split('/'))

# 5、方法lower,返回字符串的小写版本,而upper,返回字符串的大写版本
lo = "HeLlO"
print("lower:", lo.lower())
print("upper:", lo.upper())

# 6、方法replace,将指定子串都替换成另一个字符串
print("replace:", s.replace("world", "leo-zu"))

# 7、方法strip,将字符串开头和末尾的空白删除,并返回删除后的结果
stripstr = "    123   "
print("strip:", stripstr.strip())

# 8、方法translate,替换字符串的特定部分,但不同的是它只能进行单字符替换
# 并且可以同时替换多个字符
# 首先创建转换表,maketrans的第三个参数:指定要将哪些字母删除。
table = str.maketrans('cs', 'kz')
print("查看转换表:", table)
tx = 'this is incredible test'
print("translate:", tx.translate(table))
# ---------------
# center: ****hello world*****
# find: 0
# join: 1+2+3+4
# split: ['', 'usr', 'bin', 'env']
# lower: hello
# upper: HELLO
# replace: hello leo-zu
# strip: 123
# 查看转换表: {99: 107, 115: 122}
# translate: thiz iz inkredible tezt
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章