字符串介绍
一. 认识字符串
字符串是 Python 中最常用的数据类型。我们一般使用引号来创建字符串。创建字符串很简单,只要为变量分配一个值即可。
a = 'hello world'
b = "abcdefg"
print(type(a))
print(type(b))
注意:控制台显示结果为
<class 'str'>
, 即数据类型为str(字符串)。
1.1 字符串特征
-
一对引号字符串
name1 = 'Tom'
name2 = "Rose"
-
三引号字符串
name3 = ''' Tom '''
name4 = """ Rose """
a = ''' i am Tom, nice to meet you! '''
b = """ i am Rose, nice to meet you! """
注意:三引号形式的字符串支持换行。
二.字符串输出
1.格式化操作符
name = '小李'position = '讲师'address = '北京市'
print('--------------------------------------------------')print("姓名:%s" % name)print("职位:%s" % position)print("公司地址:%s" % address)print('--------------------------------------------------')
结果:
--------------------------------------------------姓名: 小李职位: 讲师公司地址: 北京市--------------------------------------------------
2.f-strings
f-strings 提供一种简洁易读的方式, 可以在字符串中包含 Python 表达式. f-strings 以字母 'f' 或 'F' 为前缀, 格式化字符串使用一对单引号、双引号、三单引号、三双引号. 格式化字符串中
f-strings
的基本结构是这样的:
name = '小李'
age = 18
sex = '男'
msg1 = F'姓名:{name},性别:{age},年龄:{sex}' # 大写字母也可以
msg = f'姓名:{name},性别:{age},年龄:{sex}' # 建议小写
print(msg)
输出的结果为:
姓名:小李,性别:18,年龄:男
f-strings
就是在字符串的引号前面加上一个字母 f
。字母大小写都可以,但是推荐使用小写。{}
中除了可以使用变量外,还可以放入函数:
def func(a,b):return a + b
msg = f"运行结果:{func(1,2)}"
print(msg)
输出的结果为:
运行结果:3
甚至可以在 {}
中放入 input
函数,让用户输入:
print(f"姓名:{input('请输入姓名:')} 年龄:{input('请输入年龄:')} 性别:{input('请输入性别:')}")
输出的结果是:
请输入姓名:alex 请输入年龄:18 请输入性别:男 姓名:alex 年龄:18 性别:男
除了字符串,{} 中也可以放入列表和字典:
lst = [1, 2, 32, 34, 45, 5]
msg = f"运行结果:{lst[0:3]}"
print(msg)dic = {"key": 1, "key1": 22}
msg = f"运行结果:{dic['key1']}"
print(msg)
输出的结果为:
运行结果:[1, 2, 32] 运行结果:22
f-string
可以写成多行的形式,但依然打印成一行:
msg = f"窗前明月{'光'}," \f"玻璃好上{'霜'}。" \f"要不及时{'擦'}," \f"一会就得{'脏'}。"
print(msg)
输出的结果为:
窗前明月光,玻璃好上霜。要不及时擦,一会就得脏。
要想打印多行字符串,还是要使用三对引号:
msg = f"""
窗前明月{'光'},
玻璃好上{'霜'}.
要不及时{'擦'},
一会就得{'脏'}.
"""
print(msg)
通过使用三元运算,配合 f-strings,我们可以进一步节省代码:
a = 10
b = 20
msg = f"{a if a < b else b}"
print(msg)
同时使用两个括号表示一个可以打印的大括号:
msg = f"{{'alex': 'wusir'}}"
print(msg)
输出的结果为:
{'alex': 'wusir'}
字符串输入;
注意:input获取的数据,都以字符串的方式进行保存,即使输入的是数字,那么也是以字符串方式保存
demo:
userName = input('请输入用户名:')print("用户名为:%s" % userName)
password = input('请输入密码:')print("密码为:%s" % password)
结果:(根据输入的不同结果也不同)
请输入用户名:xiaoli用户名为: 110请输入密码:123456密码为: 123456
下标和切片
1. 下标索引
所谓“下标”
,就是编号,就好比超市中的存储柜的编号,通过这个编号就能找到相应的存储空间
字符串中"下标"的使用
列表与元组支持下标索引好理解,字符串实际上就是字符的数组,所以也支持下标索引。
如果有字符串:name = 'abcdef'
,在内存中的实际存储如下:
如果想取出部分字符,那么可以通过下标
的方法,(注意python中下标从 0 开始)
name = 'abcdef'
print(name[0])print(name[1])print(name[2])
运行结果:
a b c
2. 切片
切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。
切片的语法:[起始:结束:步长]
注意:选取的区间从"起始"位开始,到"结束"位的前一位结束(不包含结束位本身),步长表示选取间隔。
我们以字符串为例讲解。
如果取出一部分,则可以在中括号[]中,使用:
name = 'abcdef'
print(name[0:3]) # 取 下标0~2 的字符
运行结果:
name = 'abcdef'
print(name[0:5]) # 取 下标为0~4 的字符
运行结果:
name = 'abcdef'
print(name[3:5]) # 取 下标为3、4 的字符
运行结果:
name = 'abcdef'
print(name[2:]) # 取 下标为2开始到最后的字符
运行结果:
name = 'abcdef'
print(name[1:-1]) # 取 下标为1开始 到 最后第2个 之间的字符
运行结果:
想一想
-
(面试题)给定一个字符串aStr, 请反转字符串
# 索引是通过下标取某个元素
# 切片是通过下标去某一段元素
s = 'Hello World!'
print(s[4])
print(s)
print(s[:]) # 取出所有元素(没有起始位和结束位之分),默认步长为1
print(s[1:]) # 从下标为1开始,取出 后面所有的元素(没有结束位)
print(s[:5]) # 从起始位置开始,取到 下标为5的前一个元素(不包括结束位本身)
print(s[:-1]) # 从起始位置开始,取到 倒数第一个元素(不包括结束位本身)
print(s[-4:-1]) # 从倒数第4个元素开始,取到 倒数第1个元素(不包括结束位本身)
print(s[1:5:2]) # 从下标为1开始,取到下标为5的前一个元素,步长为2(不包括结束位本身)
# python 字符串快速逆置
print(s[::-1]) # 从后向前,按步长为1进行取值
字符串常见操作
如有字符串mystr = 'hello world itcast and itcastcpp'
,以下是常见的操作
<1>find
检测 str 是否包含在 mystr中,如果是返回开始的索引值,否则返回-1
-
语法
字符串序列.find(子串, 开始位置下标, 结束位置下标)
-
示例
mystr.find(str, start=0, end=len(mystr))
<2>index
跟find()方法一样,只不过如果str不在 mystr中会报一个异常.
-
语法
字符串序列.index(子串, 开始位置下标, 结束位置下标)
-
示例
mystr.index(str, start=0, end=len(mystr))
<3>count
返回 str在start和end之间 在 mystr里面出现的次数
-
语法
字符串序列.count(子串, 开始位置下标, 结束位置下标)
-
示例
mystr.count(str, start=0, end=len(mystr))
<4>replace
把 mystr 中的 str1 替换成 str2,如果 count 指定,则替换不超过 count 次.
-
语法
字符串序列.replace(旧子串, 新子串, 替换次数)
-
示例
mystr.replace(str1, str2, mystr.count(str1))
<5>split
以 str 为分隔符切片 mystr,如果 maxsplit有指定值,则仅分隔 maxsplit 个子字符串
-
语法
字符串序列.split(分割字符, num)
-
示例
mystr.split(str=" ", 2)
<6>capitalize
把字符串的第一个字符大写
mystr.capitalize()
<7>title
把字符串的每个单词首字母大写
>>> a = "hello itcast"
>>> a.title()
'Hello Itcast'
<8>startswith
检查字符串是否是以 hello 开头, 是则返回 True,否则返回 False
-
语法
字符串序列.startswith(子串, 开始位置下标, 结束位置下标)
2.示例
mystr.startswith(hello)
<9>endswith
检查字符串是否以obj结束,如果是返回True,否则返回 False.
mystr.endswith(obj)
<10>lower
转换 mystr 中所有大写字符为小写
mystr.lower()
<11>upper
转换 mystr 中的小写字母为大写
mystr.upper()
<12>ljust
返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
mystr.ljust(width)
<13>rjust
返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
mystr.rjust(width)
<14>center
返回一个原字符串居中,并使用空格填充至长度 width 的新字符串
mystr.center(width)
<15>lstrip
删除 mystr 左边的空白字符
mystr.lstrip()
<16>rstrip
删除 mystr 字符串末尾的空白字符
mystr.rstrip()
<17>strip
删除mystr字符串两端的空白字符
>>> a = "\n\t itcast \t\n"
>>> a.strip()
'itcast'
<18>rfind
类似于 find()函数,不过是从右边开始查找.
mystr.rfind(str, start=0,end=len(mystr) )
<19>rindex
类似于 index(),不过是从右边开始.
mystr.rindex( str, start=0,end=len(mystr))
<20>partition
把mystr以str分割成三部分,str前,str和str后
mystr.partition(str)
<21>rpartition
类似于 partition()函数,不过是从右边开始.
mystr.rpartition(str)
<22>splitlines
按照行分隔,返回一个包含各行作为元素的列表
mystr.splitlines()
<23>isalpha
如果 mystr 所有字符都是字母 则返回 True,否则返回 False
mystr.isalpha()
<24>isdigit
如果 mystr 只包含数字则返回 True 否则返回 False.
mystr.isdigit()
<25>isalnum
如果 mystr 所有字符都是字母或数字则返回 True,否则返回 False
mystr.isalnum()
<26>isspace
如果 mystr 中只包含空格,则返回 True,否则返回 False.
mystr.isspace()
<27>join
mystr 中每个元素后面插入str,构造出一个新的字符串
-
语法
字符或子串.join(多字符串组成的序列)
-
示例
mystr.join(str)
#想一想
-
(面试题)给定一个字符串aStr,返回使用空格或者'\t'分割后的倒数第二个子串