测试环境:Centos7+Python3.5
1.字符串拼接
正常情况用 “+” 号即可拼接字符串。但如果不用“+”号相邻的两个或多个字符串也会自动连接。
# 相邻的两个或多个字符串会自动连接
>>> 'Py' 'thon'
'Python'
2.字符串转义
参考: http://www.runoob.com/python/python-strings.html
对于Python而言,正常情况是默认转义的,如下:
# 默认转义
>>> print('C:\some\name')
C:\some
ame
如果不想转义的话,可以在字符串前面添加 r(real)
>>> print(r'C:\some\name')
C:\some\name
3.字符串重复
>>> 'ha' * 3
'hahaha'
4.字符串切片
字符串也可看作一个字符列表,所以可以像列表那样支持切片和索引,在此不再赘述。
5.字符串的分割
>>> a = 'aa bb'
>>> a.split(' ') # 空格分割
['aa', 'bb']
6.字符串的替换
>>> a.replace('aa', 'cc') # 空格替换
'cc bb'
注:当输入的字符串没有规律时,用split和replace有点危险,因为有可能其它字符也会被分割替换
7.字符串格式化
字符串格式化有多种方式, 有 % 或者format函数,现在Python越来越推崇用 format 函数。
主要参考这篇文章:https://www.cnblogs.com/wilber2013/p/4641616.html
%c:转换成字符(ASCII 码值,或者长度为一的字符串)
%r:优先用repr()函数进行字符串转换
%s:优先用str()函数进行字符串转换
%d / %i / %u:转成有符号十进制数。%u 本来是无符号十进制数,但是在文档中 %u 和 %d 是等同的。
%o:转成无符号八进制数
%x / %X:转成无符号十六进制数(x / X 代表转换后的十六进制字符的大小写)
%e / %E:转成科学计数法(e / E控制输出e / E)
%f / %F:转成浮点数(小数部分自然截断)
%%:输出% (格式化字符串里面包括百分号,那么必须使用%%)
>>> string = 'Hello\tWorld\n'
>>> print("%r" %string)
'Hello\tWorld\n'
>>> print("%s" %string)
Hello World
>>> i = 18
>>> f = 40.0234
>>> s = 'John'
>>> print('the age of %s is %d, his salary are %.2f' % (s, i, f))
the age of John is 18, his salary are 40.02
>>> i = 1222222222
>>> print('%e' %i)
1.222222e+09
格式化操作符辅助符
m.n: m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)
%.2f: m未指定,所以无穷; n指定2,所以保留两位。
格式化内建函数
Format 內建函数有两种表现形式。第一种是通过数字来表示是第几个参数;第二种是通过关键字参数来表示,如下:
# 数字表示
>>> "hello {0}".format("John")
'hello John'
amp;ensp;
# 关键字参数
>>> "hello {name}, your uid is {uid}".format(name="John", uid=123)
'hello John, your uid is 123'
8.补充
- str()和repr()两个内建函数之间的差异:
str()得到的字符串是面向用户的,具有较好的可读性;
repr()得到的字符串是面向机器的
>>> string = "Hello\tWill\n"
>>> print("%s" % string)
>>> print("%r" % string)
Hello Will
amp;ensp;
'Hello\tWill\n'