⛄字符串的定义
字符串就是一串字符,用途众多,是编程语言中表示文本的数据类型,如"Hello World"。在Python中可以使用一对双引号" "
或者一对单引号''
定义一个字符串。虽然可以使用\"
或者\'
做字符串的转义,但是在实际开发中:
- 如果字符串内部需要使用
"
,可以使用'
定义字符串 - 如果字符串内部需要使用
'
,可以使用"
定义字符串
可以使用索引获取一个字符串中指定位置的字符,索引计数从0开始;也可以使用for
循环遍历字符串中每一个字符。
str1 = "My name is 'xiaotang'"
str2 = 'My name is "HeartLoveLife"'
# len(字符串)获取字符串的长度
str1_len = len(str1)
str2_len = len(str2)
print(str1, ";", str2)
print(str1_len, ";", str2_len)
# 字符串.count(字符串)统计小字符串在大字符串中出现的次数
print(str1.count("n"))
# 字符串[索引]从字符串中取出单个字符
print(str1[0])
# 字符串.index(字符串)获得小字符串第一次出现的索引
print(str1.index("n"))
# 输出结果
My name is 'xiaotang' ; My name is "HeartLoveLife"
21 ; 26
2
M
3
⛄字符串常用操作
Python内置提供的方法有很多,使得在开发时,能够针对字符串进行更加灵活的操作,应对更多的开发需求。使用Python内置函数dir()返回字符串的属性、方法列表。
str_list = dir("")
print(str_list)
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
👀 判断类型
方法 | 说明 |
---|---|
string.isspace() | 如果string中只包含空格,则返回True |
string.isalnum() | 如果string至少有一个字符并且所有字符都是字母或数字则返回True |
string.isalpha() | 如果string至少有一个字符并且所有字符都是字母则返回True |
string.isdecimal() | 如果 string只包含数字则返回True,全角数字 |
string.isdigit() | 如果 string只包含数字则返回True,全角数字 |
string.isnumeric() | 如果 string只包含数字则返回True,全角数字 ,汉字数字 |
string.istitle() | 如果 string是标题化的(每个单词的首字母大写)则返回True |
string.islower() | 如果string中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回True |
string.isupper() | 如果 string中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回True |
str_space = " "
print(str_space.isspace())
str1 = "a_"
str2 = "a9527"
print(str1.isalnum(), str2.isalnum())
str3 = "a9527"
str4 = "abc"
print(str3.isalpha(), str4.isalpha())
str5 = "9527"
str6 = "1"
str7 = "一"
print(str5.isdecimal(), str6.isdigit(), str7.isnumeric())
str8 = "Xiaotang"
print(str8.istitle())
str9 = "xiaotang"
str10 = "XIAOTANG"
print(str9.islower(), str10.isupper())
# 结果
True
False True
False True
True True True
True
True True
👀 查找和替换
方法 | 说明 |
---|---|
string.startswith(str) | 检查字符串是否是以str开头,是则返回True |
string.endswith(str) | 检查字符串是否是以str结束,是则返回True |
string.find(str,start=0,end=len(string)) | 检测str是否包含在string中,如果start和end指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1 |
string.rfind(str,start=0,end=len(string)) | 类似于find(),不过是从右边开始查找 |
string.index(str,start=0,end=len(string)) | 跟find()方法类似,不过如果str不在string会报错 |
string.rindex(str,start=0,end=len(string)) | 类似于index(),不过是从右边开始 |
string.replace(old_str,new_str,num=string.count(old)) | 把string中的old_str替换成new_str,如果num指定,则替换不超过num次 |
str1 = "his name is xiaotang, see you"
print(str1.startswith("his"), str1.endswith("you"))
print(str1.find("is", 0, 5), str1.rfind("is"), str1.find("iss"))
print(str1.index("is"), str1.rindex("is"))
print(str1.replace("xiaotang", "heartlovelife"))
# 结果
True True
1 9 -1
1 9
his name is heartlovelife, see you
👀 大小写转换
方法 | 说明 |
---|---|
string.capitalize() | 把字符串的第一个字符大写 |
string.title() | 把字符串的每个单词首字母大写 |
string.lower() | 转换string中所有大写字符为小写 |
string.upper() | 转换string中的小写字母为大写 |
string.swapcase() | 翻转string中的大小写 |
str1 = "xiao tang heLLo heLLo"
print(str1.capitalize())
print(str1.title())
print(str1.lower())
print(str1.upper())
print(str1.swapcase())
# 结果
Xiao tang hello hello
Xiao Tang Hello Hello
xiao tang hello hello
XIAO TANG HELLO HELLO
XIAO TANG HEllO HEllO
👀 文本对齐
方法 | 说明 |
---|---|
string.ljust(width,[填充字符]) | 返回一个原字符串左对齐,并使用填充字符(默认空格)填充至长度width的新字符串 |
string.rjust(width,[填充字符]) | 返回一个原字符串右对齐,并使用填充字符(默认空格)填充至长度width的新字符串 |
string.center(width,[填充字符]) | 返回一个原字符串居中,并使用填充字符(默认空格)填充至长度width的新字符串 |
str1 = "-xiaotang hello hello-"
print(str1.ljust(50,"a"))
print(str1.rjust(50,"b"))
print(str1.center(50,"a"))
# 结果
-xiaotang hello hello-aaaaaaaaaaaaaaaaaaaaaaaaaaaa
bbbbbbbbbbbbbbbbbbbbbbbbbbbb-xiaotang hello hello-
aaaaaaaaaaaaaa-xiaotang hello hello-aaaaaaaaaaaaaa
👀去除空白字符
方法 | 说明 |
---|---|
string.lstrip() | 截掉string左边(开始)的空白字符 |
string.rstrip() | 截掉string右边(末尾)的空白字符 |
string.strip() | 截掉 string左右两边的空白字符 |
str1 = " xiaotangxiaotang "
print("="*5, str1.lstrip(), "="*5)
print("="*5, str1.rstrip(), "="*5)
print("="*5, str1.strip(), "="*5)
# 结果
===== xiaotangxiaotang =====
===== xiaotangxiaotang =====
===== xiaotangxiaotang =====
👀拆分和连接
方法 | 说明 |
---|---|
string.partition(str) | 把字符串string分成一个3元素的元组(str前面,str,str 后面) |
string.rpartition(str) | 类似于partition()方法,不过是从右边开始查找 |
string.split(str=“”,num) | 以str为分隔符拆分string,返回列表;如果num有指定值,则仅分隔num+1个子字符串,str默认包含’r’,‘t’,'n’和空格 |
string.splitlines() | 按照行(‘r’,‘n’,‘rn’)分隔,返回一个包含各行作为元素的列表 |
string.join(seq) | 以string作为分隔符,将seq(要连接的元素序列)中所有的元素合并为一个新的字符串 |
str1 = "xiaotang=or=xiaoming=or=xiaolizi"
str2 = "xiaotang=or=xiaoming=or=xiaolizi\nxiaotang"
str3 = ("I","love","you")
str4 = ["I","love","you"]
print(str1.partition("or"))
print(str1.rpartition("or"))
print(str1.split("="))
print(str2.splitlines())
print("@".join(str3))
print("#".join(str4))
# 结果
('xiaotang=', 'or', '=xiaoming=or=xiaolizi')
('xiaotang=or=xiaoming=', 'or', '=xiaolizi')
['xiaotang', 'or', 'xiaoming', 'or', 'xiaolizi']
['xiaotang=or=xiaoming=or=xiaolizi', 'xiaotang']
I@love@you
I#love#you
👀字符串的切片
切片方法适用于字符串、列表、元组
- 切片使用索引值来限定范围,从一个大的字符串中切出小的字符串
- 列表和元组都是有序的集合,都能够通过索引值获取对应的数据
- 字典是一个无序的集合,是使用键值对保存数据
注意事项:
- 指定的区间属于左闭右开型
[开始索引,结束索引]
相当于从起始位开始,到结束位的前一位结束(不包含结束位本身) - 从头开始,开始索引数字可以省略,冒号不能省略
- 到末尾结束,结束索引数字可以省略,冒号不能省略
- 步长默认为1,如果连续切片,数字和冒号都可以省略
- 不仅支持顺序索引,还支持倒序索引;所谓倒序索引就是从右向左计算索引,最右边的索引值是**-1**,依次递减。
str = "xiaotang9527helloworld"
# 截取3~6位置的字符串,相当于索引为[2:5],因为不包含末尾,所以为[2,6]
print(str[2:6])
# 截取3~末尾的字符串
print(str[2:])
# 截取从开始~6位置的字符串,6位置相当于索引为5,因为不包含末尾,所以为[:6]
print(str[:6])
# 取完整的字符串
print(str[:])
# 从开始位置,每隔一个字符截取字符串
print(str[::2])
# 倒序切片
# -1表示倒数第一个字符
print(str[-1])
# 截取3-末尾的字符串(不包含最后一个字符)
print(str[2:-1])
# 截取字符串末尾两个字符
print(str[-2:])
# 字符串的逆序
print(str[::-1])
# 结果
aota
aotang9527helloworld
xiaota
xiaotang9527helloworld
xatn92hlool
d
aotang9527helloworl
ld
dlrowolleh7259gnatoaix
⛄公共方法及特殊用法
👀内置函数
函数 | 描述 | 备注 |
---|---|---|
len(item) | 计算容器中元素个数 | |
del(item) | 删除变量 | del有两种方式 |
max(item) | 返回容器中元素最大值 | 如果是字典,只针对key比较 |
min(item) | 返回容器中元素最小值 | 如果是字典,只针对key比较 |
cmp(item1,item2) | 比较两个值,-1小于/0相等/1大于 | Python3.x取消了cmp函数 |
👀运算符特殊用法
运算符 | 表达式 | 结果 | 描述 | 支持数据类型 |
---|---|---|---|---|
+ | [1,2] + [3,4] | [1,2,3,4] | 合并 | 字符串、列表、元组 |
* | [“a”] * 2 | [“a”,“a”] | 重复 | 字符串、列表、元组 |
in | 2 in (1,2,3) | True | 元素是否存在 | 字符串、列表、元组、字典 |
not in | 5 not in(1,2,3) | True | 元素是否不存在 | 字符串、列表、元组、字典 |
in
在对字典操作时,判断的是字典的键;in
和not in
被称为成员运算符,用于测试序列中是否包含指定的成员。
👀完成的for循环语法·
在Python中完整的for
循环语法如下:
for 变量 in 集合:
循环体代码
else:
没有通过break退出循环,循环结束后,会执行的代码
应用场景
- 在迭代遍历嵌套的数据类型时,例如一个列表包含了多个字典
- 需求:判断某一个字典中,是否存在指定的值
- 如果存在,提示并且退出循环
- 如果不存在,在循环整体结束后,希望得到一个统一的提示
# 第一种
stu = [
{"name": "xiaotang",
"age": "25",
"gender": True,
"height": 180,
"weight": 66},
{"name": "xiaoming",
"age": "26",
"gender": True,
"height": 179,
"weight": 65}
]
find_name = "xiaotang"
for stu_dict in stu:
print(stu_dict)
# 判断当前遍历的字典中姓名是否为find_name
if stu_dict["name"] == find_name:
print("找到阿汤了")
# 如果找到,直接退出循环,不需对后续的数据进行比较
break
else:
print("怎么搞的,没有找到!!")
print("循环结束")
# 结果
{'name': 'xiaotang', 'age': '25', 'gender': True, 'height': 180, 'weight': 66}
找到阿汤了
循环结束
# 第二种
stu = [
{"name": "xiaotang",
"age": "25",
"gender": True,
"height": 180,
"weight": 66},
{"name": "xiaoming",
"age": "26",
"gender": True,
"height": 179,
"weight": 65}
]
find_name = "xiaotang1"
for stu_dict in stu:
print(stu_dict)
# 判断当前遍历的字典中姓名是否为find_name
if stu_dict["name"] == find_name:
print("找到阿汤了")
# 如果找到,直接退出循环,不需对后续的数据进行比较
break
else:
print("怎么搞的,没有找到!!")
print("循环结束")
# 结果
{'name': 'xiaotang', 'age': '25', 'gender': True, 'height': 180, 'weight': 66}
{'name': 'xiaoming', 'age': '26', 'gender': True, 'height': 179, 'weight': 65}
怎么搞的,没有找到!!
循环结束
欢迎大家关注预览我的博客Blog:HeartLoveLife
能力有限,敬请谅解!!