1 初识字符串
字符串是 Python 中最常用的数据类型。我们一般使用引号(’'或"")来创建字符串,为变量分配一个值即可。
# 单引号创建字符串 var1='hello world' # 双引号创建字符串 var2='hello world' # 三个引号(''')里面能出现单引号双引号回车键等,三个引号中字符串会保持传入的格式。 var3="""hello world"""
1.1 字符串的连接
连接字符串用’+‘
a='hello' b='world' print(a+b)
1.2 特殊情况
当输入的字符串内容中包含引号(单或双)如何处理
- 使用包含单引号,外面就用双引号
# 输出:I'm a boy. print("I'm a boy")
- 使用转义字符
print('I\'m a boy')
1.3 常用转义字符
2 索引(下标)
“下标”又叫“索引”,就是编号。比如火车座位号,座位号的作用:按照编号快速找到对应的座位。同理,下标的作用即是通过下标快速找到对应的数据。有数组学习的基础相信这一部分知识点掌握起来并不费力!
代码示例:
var='hello' #下标从0开始,因此这5个字母下标分别为0,1,2,3,4 print(var[0])
注意:第一个用 0 的语言是 BCPL,它是 C 的前身。由于C 的巨大成功,很多语言受它影响采用从 0 开始。例如 C, C++, Java, Python, JavaScript, Go。
3 切片操作
切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。
语法如下:
序列[开始位置下标:结束位置下标:步长] # 1. 不包含结束位置下标对应的数据, 正负整数均可; # 2. 步长是选取间隔,正负整数均可,默认步长为1。
示例:
name = "abcdefg" print(name[2:5:1]) # cde print(name[2:5]) # cde print(name[:5]) # abcde print(name[1:]) # bcdefg print(name[:]) # abcdefg print(name[::2]) # aceg print(name[:-1]) # abcdef, 负1表示倒数第一个数据 print(name[-4:-1]) # def print(name[::-1]) # gfedcba
4 字符串的常用方法(附示例)
字符串的函数有许多,主要从常用的入手,慢慢积累!
4.1 查找
4.1.1 find()
语法如下:
字符串序列.find(子串, 开始位置下标, 结束位置下标) #检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则返回-1。
注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。
示例:
mystr = "hello world and itcast and itheima and Python" print(mystr.find('and')) # 12 print(mystr.find('and', 15, 30)) # 23 print(mystr.find('ands')) # -1
其他查找相关函数
- string.index(子串,开始位置下标,结束位置下标)
- string.rfind(子串,开始位置下标,结束位置下标):和find()功能相同,但查找方向为右侧开始。
- string.rindex(子串,开始位置下标,结束位置下标):注意:未找到sub时会报出异常
- string.count(子串, 开始位置下标, 结束位置下标):返回某个子串在字符串中出现的次数,开始和结束位置下标可以省略,表示在整个字符串序列中查找。
4.2 修改
修改字符串,指的就是通过函数的形式修改字符串中的数据。
4.2.1 replace()
语法如下:
字符串序列.replace(旧子串, 新子串, 替换次数) # 示例 mystr = "hello world and itcast and itheima and Python" # 结果:hello world he itcast he itheima he Python print(mystr.replace('and', 'he')) # 结果:hello world he itcast he itheima he Python print(mystr.replace('and', 'he', 10)) # 结果:hello world and itcast and itheima and Python print(mystr)
注意:
可以指定替换的个数,默认全部替换。字符串类型的数据修改的时候不能改变原有字符串,属于不能直接修改数据的类型即是不可变类型。
4.2.2 split()
指定字符分割字符串
语法如下:
字符串序列.split(分割字符, num)
注意:num表示的是分割字符出现的次数,即将来返回数据个数为num+1个。
示例:
mystr = "hello world and itcast and itheima and Python" # 结果:['hello world ', ' itcast ', ' itheima ', ' Python'] print(mystr.split('and')) # 结果:['hello world ', ' itcast ', ' itheima and Python'] print(mystr.split('and', 2)) # 结果:['hello', 'world', 'and', 'itcast', 'and', 'itheima', 'and', 'Python'] print(mystr.split(' ')) # 结果:['hello', 'world', 'and itcast and itheima and Python'] print(mystr.split(' ', 2))
注意:如果分割字符是原有字符串中的子串,分割后则丢失该子串。
4.2.3 join()
用一个字符或子串合并字符串,即是将多个字符串合并为一个新的字符串。
语法如下:
字符或子串.join(多字符串组成的序列)
示例:
list1 = ['chuan', 'zhi', 'bo', 'ke'] t1 = ('aa', 'b', 'cc', 'ddd') # 结果:chuan_zhi_bo_ke print('_'.join(list1)) # 结果:aa...b...cc...ddd print('...'.join(t1))
更多函数:
capitalize():将字符串第一个字符转换成大写。
lower():将字符串中大写转小写。
upper():将字符串中小写转大写。
lstrip():删除字符串左侧空白字符。
rstrip():删除字符串右侧空白字符。
strip():删除字符串两侧空白字符。
ljust():返回一个原字符串左对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串。
rjust():返回一个原字符串右对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串,语法和ljust()相同。
center():返回一个原字符串居中对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串,语法和ljust()相同。
4.3 判断
判断即是判断真假,返回的结果是布尔型数据类型:True 或 False。
- startswith():检查字符串是否是以指定子串开头,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
- endswith()::检查字符串是否是以指定子串结尾,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
- isalpha():如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False。
- isalnum():如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False。
- isspace():如果字符串中只包含空白,则返回 True,否则返回 False。
相关链接:
python字符串详解 - Jerry! - 博客园 (cnblogs.com)
Python入门 字符串处理(字符串连接\转义\字符串运算\字符串的多种引号区分\切片\常用函数) - 木头人的文章 - 知乎
E.W. Dijkstra Archive: Why numbering should start at zero (EWD 831) (utexas.edu)