- 字符串格式化
字符串格式化使用字符串格式化操作符即百分号%来实现。在%的左侧放置一个字符串(格式化字符串),而在右侧则放置希望格式化的值,可以使用一个值,如一个字符串或者数字,也可以使用多个值的元组或者字典,如
>>> print "hello. %s.%s enough for ya?" % ('world', 'Hot')
hello. world.Hot enough for ya?
如果右操作数是元组的话,则其中的每一个元素都会被单独格式化,每个值都需要一个对应的转换说明符。
基本的转换说明符包括以下部分,注意,这些项的顺序是至关重要的。
1. %字符:标记转换说明符的开始。
2. 转换标志(可选):-表示左对齐;+表示在转换值之前要加上正负号;“”表示正数之前保留空格;0表示转换值若位数不够则用0填充。
3. 最小字段宽度(可选):转换后的字符串至少应该具有该值指定的宽度。如果是*,则宽度会从值元组中读出。
4. 点(.)后跟精度值(可选):如果转换的是实数,精度值就表示出现在小数点后的位数。如果转换的是字符串,那么该数字就表示最大字段宽度。如果是*,那么精度将会从元组中读出。
5. 转换类型:见下表
如
#使用给定的宽度打印格式化后的价格列表
width = input('width:')
price_width = 10
item_width = width - price_width
header_format = '%-*s%*s'
format = '%-*s%*.2f'
print '-' * width
print header_format % (item_width, 'Item', price_width, 'Price')
print '-' * width
print format % (item_width, 'Apples', price_width, 0.4)
print format % (item_width, 'Pears', price_width, 0.5)
print format % (item_width, 'Cantaloupes', price_width, 1.92)
print format % (item_width, 'Dried Apricots(16 0z.)', price_width, 8)
print format % (item_width, 'prunex(4 1bs)', price_width, 12)
print '=' * width
结果如下
width:35
-----------------------------------
Item Price
-----------------------------------
Apples 0.40
Pears 0.50
Cantaloupes 1.92
Dried Apricots(16 0z.) 8.00
prunex(4 1bs) 12.00
=======================
- 字符串方法
find -- 在一个较长的字符串中找子字符串,它返回子串所在位置的最左端索引,未找到则返回-1。此方法还接收可选的起始点和结束点参数。
>>> title = 'hello. world.Hot enough for ya?'
>>> title.find('wor')
7
>>> title.find('wor', 2, 6)
-1
join -- 在队列中添加元素
>>> seq = list('12345')
>>> sep = '+'
>>> sep.join(seq)
'1+2+3+4+5'
>>> dirs = '','usr','bin','env'
>>> '/'.join(dirs)
'/usr/bin/env'
>>> 'C:'+'\\'.join(dirs)
'C:\\usr\\bin\\env'
lower -- 返回字符串的小写字母版
replace -- 返回某字符串的所有匹配项均被替换之后得到的字符串。
split -- 将字符串分割成序列
>>> '1+2+3+4+5'.split('+')
['1', '2', '3', '4', '5']
>>> '/usr/bin/env'.split('/')
['', 'usr', 'bin', 'env']
>>> 'C:\\usr\\bin\\env'.split('\\')
['C:', 'usr', 'bin', 'env']
strip -- 返回除去两侧(不包括内部)空格的字符串,也可以指定需要去除的字符。
>>> '++!**1+2+3+4+5*++'.strip('+!*')
'1+2+3+4+5'
translate -- 可以替换字符串中的某些部分,只处理单个字符,并且可以同时进行多个替换。第一个参数指定需要替换的表,第二个参数指定需要删除的字符。
>>> from string import maketrans
>>> table = maketrans('cs', 'kz')
>>> 'This is an incredible test'.translate(table)
'Thiz iz an inkredible tezt'>>> 'This is an incredible test'.translate(table, ' ')
'Thizizaninkredibletezt'