「Python基础」字符串类型

测试环境: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'

9.参考教程

Python格式化字符串
PYTHON的小坑:%U

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容