知识点总结
- 字符串分片
str1[:6]
- 和访问字符串
str1[2]
- 更新字符串跟元组差不多
- 字符串的内置方法
方法 | 定义 |
---|---|
capitalize() | 把字符串的第一个字符改为大写,PS,是返回一个新的字符串,没有改变旧的字符串 |
caseflod() | 把整个字符串的所有字符改为小写 |
center(width) | 把字符串居中,并使用空格填充至长度为width的新字符串,也就把那个长度平均分 |
count(sub[,start[,end]]) | 返回sub在字符串里出现的次数,start和end参数表示范围,可选 |
encode() | 以encoding指定的编码格式对字符串进行编码 |
endswith(sub[,start[,end]]) | 坚持字符串是否以sub子字符串结束,是则返回True,否则返回假,start,end参数表示范围可选 |
expandtabs([tabsize=8]) | 把字符串中的的tab符号(\t转换为空格),如不指定参数,默认的空格数tabsize=8,到底是怎样使用的 |
find(sub[,start[,end]]) | 检测sub是否包含在字符串中,如果有则返回索引值,否则返回-1,start和end参数表示范围,可选 |
index(sub[,start[,end]]) | 跟find方法一样,不过如果sub不在string中会产生一个异常 |
isalnum() | 如果字符串至少有一个字符并且所有字符都是字母或数字则返回True,否则返回False |
isalpha() | 如果字符串至少有一个字符并且所有字符都是字母则返回True,否则返回False |
isdecimal() | 如果字符串中只包含十进制数字则返回True,否则返回False |
isdigit() | 如果字符串中只包含数字则返回True,否则返回False |
islower() | 如果字符串中至少包含一个区分大小写的字符,并且这些字符都是小写,则返回True,否则返回False |
isnumeric() | 如果字符串只包含数字字符,则返回True,否则返回False |
isspace() | 如果字符串中只包含空格,则返回True,否则返回False |
istitle() | 如果字符串是标题化(所有的单词都是以大写开始,其余字母均小写),则返回True,否则返回False |
isupper() | 如果字符串中至少包含一个区分大小写的字符,并且这些字符都是大写,则返回True,否则返回False |
join(sub) | 以字符串作为分隔符,插入到sub中的所有的字符之间 |
ljust(width) | 返回一个左对齐的字符串,并使用空格填充至长度为width的新的字符串, |
lower() | 转换为字符串中所有的大写字符为小写 |
lstrip() | 去掉字符串左边的所有空格 |
partition(sub) | 找到子字符串sub,把字符擦混分成一个3元组(pre_sub,sub,fol_sub),如果字符串中不包含sub则返回(‘原字符串’,’ ‘,’ ‘) |
replace(old,new[,count]]) | 把字符串中的old子字符串替换成new子字符串,如果count指定,则替换不超过count次 |
rfind(sub[,start[,end]) | 类似于find()方法,不过是从右边开始查找 |
rindex(sub[,start[,end]) | 类似于index()方法,不过是从右边开始查找 |
rjust(width) | 返回一个右对齐的字符串,并使用空格填充至长度为width的新字符串 |
rpartition(sub) | 类似于partition()方法,不过是从右边开始查找 |
rstrip() | 删除字符串末尾的空格 |
split(sep = None,maxsplit=-1) | 不带参数默认是以空格为分割符切片字符串,如果maxsplit参数有设置,则仅分割maxsplit个子字符串,返回切片后的字符串拼接的列表 |
splitlines(([keepends])) | 按照’\n’分隔,分会一个包含各行作为元素的列表,如果keepends参数指定,则返回前keepends行 |
startswith(prefix[,start[,end]]) | 检测字符串是否以prefix开头,是则返回True,否则返回False,start和end参数可以指定范围检查,可选 |
strip([chars]) | 删除字符串前边和后边所有的空格,chars参数可以定制删除的字符,可选 |
swapcase() | 翻转字符串中的大小写 |
title() | 返回标题化(所有的单词都是以大写开始,其余字母均小写)的字符串 |
translate(table) | 根据table的规则(可以有str.maketrans(‘a’,’b’)定制),转换字符串中的字符 |
upper() | 转换字符串中的所有小写字符为大写 |
zfill(width) | 返回长度为width的字符串,原字符串右对齐,前边用0填充 |
课后习题
测试题
题1: 还记得如何定义一个跨越多行的字符串吗(请至少写出两种实现的方法)?
方法一:
>>> str1 = '''待我长发及腰,将军归来可好?
此身君子意逍遥,怎料山河萧萧。
天光乍破遇,暮雪白头老。
寒剑默听奔雷,长枪独守空壕。
醉卧沙场君莫笑,一夜吹彻画角。
江南晚来客,红绳结发梢。'''
方法二:
>>> str2 = '待卿长发及腰,我必凯旋回朝。\
昔日纵马任逍遥,俱是少年英豪。\
东都霞色好,西湖烟波渺。\
执枪血战八方,誓守山河多娇。\
应有得胜归来日,与卿共度良宵。\
盼携手终老,愿与子同袍。'
方法三:
>>> str3 = ('待卿长发及腰,我必凯旋回朝。'
'昔日纵马任逍遥,俱是少年英豪。'
'东都霞色好,西湖烟波渺。'
'执枪血战八方,誓守山河多娇。'
'应有得胜归来日,与卿共度良宵。'
'盼携手终老,愿与子同袍。')
题2: 三引号字符串通常我们用于做什么使用?
三引号字符串不赋值的情况下,通常当作跨行注释使用,例如:
'''这是一个三引号字符串用于注释的例子,
例子虽然只是简简单单的一句话,
却毫无遮掩地体现了作者用情至深,
所谓爱至深处情至简!'''
print("I love FishC.com!")
题3: file1 = open(‘C:\windows\temp\readme.txt’, ‘r’) 表示以只读方式打开“C:\windows\temp\readme.txt”这个文本文件,但事实上这个语句会报错,知道为什么吗?你会如何修改?
会报错是因为在字符串中,我们约定“\t”和“\r”分别表示“横向制表符(TAB)”和“回车符”(详见:http://bbs.fishc.com/thread-39140-1-1.html),因此并不会按照我们计划的路径去打开文件。
Python 为我们铺好了解决的道路,只需要使用原始字符串操作符(R或r)即可:
>>> file1 = open(r'C:\windows\temp\readme.txt', 'r')
题4: 有字符串:str1 = ‘鱼C资源打包‘,请问如何提取出子字符串:’www.fishc.com’
>>> str1[16:29]
题5: 如果使用负数作为索引值进行分片操作,按照第三题的要求你能够正确目测出结果吗?
>>> str1[-45:-32]
题6: 还是第三题那个字符串,请问下边语句会显示什么内容?
>>> str1[20:-36]
‘fishc’,加入了负数索引,问题变得有些复杂,不过自己多尝试几次就可以熟练掌握了。
题7: 据说只有智商高于150的鱼油才能解开这个字符串(还原为有意义的字符串):str1 = ‘i2sl54ovvvb4e3bferi32s56h;$c43.sfc67o0cm99’
>>> str1[::3]
动动手
动动手答案:
题1: 请写一个密码安全性检查的脚本代码:check.py
# 密码安全性检查代码
#
# 低级密码要求:
# 1. 密码由单纯的数字或字母组成
# 2. 密码长度小于等于8位
#
# 中级密码要求:
# 1. 密码必须由数字、字母或特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|\)任意两种组合
# 2. 密码长度不能低于8位
#
# 高级密码要求:
# 1. 密码必须由数字、字母及特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|\)三种组合
# 2. 密码只能由字母开头
# 3. 密码长度不能低于16位