⛄字符串的定义

字符串就是一串字符,用途众多,是编程语言中表示文本的数据类型,如”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 在对字典操作时,判断的是字典的键;innot in被称为成员运算符,用于测试序列中是否包含指定的成员。

👀完成的for循环语法·

在Python中完整的for循环语法如下:

for 变量 in 集合:
循环体代码
else:
没有通过break退出循环,循环结束后,会执行的代码

应用场景

  1. 在迭代遍历嵌套的数据类型时,例如一个列表包含了多个字典
  2. 需求:判断某一个字典中,是否存在指定的值
  • 如果存在,提示并且退出循环
  • 如果不存在,在循环整体结束后,希望得到一个统一的提示
# 第一种
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}
怎么搞的,没有找到!!
循环结束