Python基础知识(04)

⛄字符串的定义

字符串就是一串字符,用途众多,是编程语言中表示文本的数据类型,如"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”]重复字符串、列表、元组
in2 in (1,2,3)True元素是否存在字符串、列表、元组、字典
not in5 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}
怎么搞的,没有找到!!
循环结束

欢迎大家关注预览我的博客Blog:HeartLoveLife
能力有限,敬请谅解!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值