系列文章目录
第一章 初识python
第二章 变量
第三章 基础语句
字符串是 Python 中最常用的数据类型。我们一般使用引号来创建字符串。创建字符串很简单,只要为变量分配一个值即可
a = 'hello world'
b = "abcdefg"
print(type(a))
print(type(b))
注意: 控制台显示结果为
name1 = 'Tom'
name2 ="Rose"
name3 = ''' Tom '''
name4 = """ Rose """
a = ''' i am Tom,
nice to meet you! '''
b = """ i am Rose,
nice to meet you! """
print('hello xy')
name = '清风微泫'
print('我的名字是%s' % name)
print(f'我的名字是{name}')
在python中,使用input()
接收用户输入
s = input('请输入内容:')
print(f'您输入的内容是{s}')
print(type(s))
mood = input('请输入您的心情:')
print(f'您输入的心情是{mood}')
print(type(mood))
“下标”又叫“索引”或叫”索引值”,就是编号。比如火车座位号,座位号的作用: 按照编号快速找到对应的座位。同理,下标的作用即是通过下标快速找到对应的数据。
注意:下标从0开始,如果是从后面开始-1代表最后一个
切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作.
语法
序列[开始位置下标:结束位置下标:步长]
注意
1.不包含结束位置下标对应的数据,正负整数均可。(左闭右开区间)
2. 步长是选取间隔,正负整数均可,默认步长为1。步长可省略不写
3. 如果不写开始,默认从0开始选取
4. 如果不写结束,表示选取到最后
5. 如果不写开始和结束,表示选取所有
6. 如果步长为负数表示倒数选取
7. 下标-1表示最后一个数据,依次向前类推
8. 如果选取方向(下标开始到结束的方向)和步长的方向冲突,则无法选取数据。从-4开始到-1结束,选取方向为从左到右侧,但是-1步长:从右向左选取。
str1="zwxhxy"
# 得到整个字符串数据
print(str1)
# 下标得到的是下标为某个数字的数据
print(str1[3]) # h
# 得到zwxh 这3个数据该怎么办?用切片
print(str1[0:3]) # zwx
print(str1[0:3:2]) # zx
print(str1[0:3:3]) # z
print(str1[0:3:4]) # z
print(str1[2:]) #xhxy
print(str1[:5]) # zwxhx
print(str1[:]) # zwxhxy
print("------------")
print(str1[::-1]) # yxhxwz
print(str1[-4:-1]) # xhx
print(str1[-4:-1:1]) # xhx
print(str1[-4:-1:-1]) # 不能选取出数据
print(str1[-1:-4:-1]) # yxh
字符串的常用操作方法有查找、修改和判断三大类
所谓字符串查找方法即是查找子串在字符串中的位置或出现的次数。
注意: 开始和结束位置下标可以省略,表示在整个字符串序列中查找
find(): 检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则返回-1
。
语法: 字符串序列.find(子串,开始位置下标,结束位置下标)
index(): 检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则报异常(报错)
。
语法: 字符串序列.index(子串,开始位置下标,结束位置下标)
rfind(): 和find()功能相同,但查找方向为右侧开始。没找到返回-1
rindex(): 和index()功能相同,但查找方向为右侧开始。可能报错
count(): 返回某个子串在字符串中出现的次数
语法: 字符串序列.count(子串,开始位置下标,结束位置下标)
mystr = 'I wander in your yard, looking forward to meeting you'
# find
print(mystr.find('you')) # 12
print(mystr.find('you', 20)) # 50
print(mystr.find('oo', 16, 40)) #24
print(mystr.find('xy')) # -1
# index
print("------index----------")
print(mystr.index("xy"))
所谓修改字符串,指的就是通过函数的形式修改字符串中的数据
注意
1.替换次数如果查出子串出现次数,则替换次数为该子串出现次数。
2.数据按照是否能直接修改分为可变类型
和不可变类型
两种。字符串类型
的数据修改的时候不能改变原有字符串,属于
不能直接修改数据的类型即是不可变类型
。
3.原有字符串的数据并没有做到修改,修改后的数据是replace函数的返回值
4.替换次数如果超出子串出现次数,表示替换所有这个子串
注意
1.num表示的是分割字符出现的次数,即将来返回数据个数为num+1个。
2. 如果分割字符是原有字符串中的子串,分割后则丢失该子串。
mystr = “
h
ello world and itcast and itheima andP
ython”
# 结果:H
ello world and itcast and itheima andp
ython
print(mystr.capitalize())
注意: capitalize()函数转换后,只字符串第一个字符大写
,其他的字符全都小写
。
mystr = “hello world and itcast and itheima and Python”
# 结果: Hello World And Itcast And Itheima And Python
print(mystr.title())
mystr = “hello world and itcast and itheima and Python”
# 结果: hello world and itcast and itheima and python
print(mystr.lower())
mystr = “hello world and itcast and itheima and Python”
# 结果: HELLO WORLD AND ITCAST AND ITHEIMA AND PYTHON
print(mystr.upper())
mystr = "hello"
newstr = mystr.ljust(10, "*")
print(newstr)
# hello*****
mystr = " I wander in your yard, looking forward to meeting you"
print(mystr.lstrip())
# I wander in your yard, looking forward to meeting you
mystr = "I wander in your yard, looking forward to meeting you "
newstr=mystr.rstrip()
print(newstr)
#I wander in your yard, looking forward to meeting you
mystr = " I wander in your yard, looking forward to meeting you "
newstr=mystr.strip()
print(newstr)
#I wander in your yard, looking forward to meeting you
所谓判断即是判断真假,返回的结果是布尔型数据类型: True 或 False。
startswith(): 检查字符串是否是以指定子串开头
,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
语法: 字符串序列.startswith(子串,开始位置下标,结束位置下标)
endswith(): 检查字符串是否是以指定子串结尾
,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
语法:字符串序列.endswith(子串,开始位置下标,结束位置下标)
mystr = "hello"
num = mystr.startswith("h") # True
num = mystr.startswith("h", 1) # False
print(num)
print(type(num)) # bool
isalpha(): 如果字符串至少有一个字符并且所有字符都是字母
则返回 True, 否则返回 False。
语法: 字符串序列.isalpha()
isdigit(): 如果字符串只包含数字
则返回 True 否则返回 False。
语法:字符串序列.isdigit()
isalnum(): 如果字符串至少有一个字符并且所有字符都是字母或数字
则返 回 True.否则返回False。
字符串序列.isalnum()
isspace():如果字符串中只包含空白(空格)
,则返回 True,否则返回 False。
字符串序列.isspace()