python常用字符串函数「详细解答」

1.数组

a = [1,2,3,5,6,7,8,9,0] print(a) #如何创建一个list
L1 = [] print(type(L1)) print(L1)
L2 = [1,2,0,3,0,5,6,7,8,9,0] print(L2 ) #增
L2.append(11) #插入到最后的一个值
print(L2) #添加到指定位置,insert(插到第几个,插入什么数据) 其他数据会向右移一个位置 #list中每个值,他们所在的位置叫做下标,这个id是从左到右从0开始
L2.insert(2,13) print(L2) #删 #remove删除的时候是通过值删除的,从左到右删除找到的第一个值 #若值不存在,报异常
L2.remove(0) print("=========") print(L2) print(L2.pop(4)) print(L2) #改
L2[1] = '111'

print(L2[1]) print(L2[3]) print(L2[6]) #遍历列表数据查询
for i in L2: print("当前元素:",i)

2.数组常用函数

len(list)
列表元素个数
max(list)
返回列表元素最大值
min(list)
返回列表元素最小值
list(seq)
将元组转换为列表
list.append(obj)
在列表末尾添加新的对象
list.count(obj)
统计某个元素在列表中出现的次数
list.extend(seq)
在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
list.index(obj)
从列表中找出某个值第一个匹配项的索引位置
list.insert(index, obj)
将对象插入列表
list.pop([index=-1])
移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
list.remove(obj)
移除列表中某个值的第一个匹配项
list.reverse()
反向列表中元素
list.sort( key=None, reverse=False)
对原列表进行排序
list.clear()
清空列表
list.copy()
复制列表

3.字符串常用函数

capitalize()
将字符串的第一个字符转换为大写
center(width, fillchar)
返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。
count(str, beg= 0,end=len(string))
返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数
bytes.decode(encoding="utf-8", errors="strict")
Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。
encode(encoding='UTF-8',errors='strict')
以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
endswith(suffix, beg=0, end=len(string))
检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
expandtabs(tabsize=8)
把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。
find(str, beg=0, end=len(string))
检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1
index(str, beg=0, end=len(string))
跟find()方法一样,只不过如果str不在字符串中会报一个异常。
isalnum()
如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False
isalpha()
如果字符串至少有一个字符并且所有字符都是字母或中文字则返回 True, 否则返回 False
isdigit()
如果字符串只包含数字则返回 True 否则返回 False..
islower()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
isnumeric()
如果字符串中只包含数字字符,则返回 True,否则返回 False
isspace()
如果字符串中只包含空白,则返回 True,否则返回 False.
istitle()
如果字符串是标题化的(见 title())则返回 True,否则返回 False
isupper()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
join(seq)
以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
len(string)
返回字符串长度
ljust(width[, fillchar])
返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。
lower()
转换字符串中所有大写字符为小写.
lstrip()
截掉字符串左边的空格或指定字符。
maketrans()
创建字符映射的转换表对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
max(str)
返回字符串 str 中最大的字母。
min(str)
返回字符串 str 中最小的字母。
replace(old, new [, max])
把 将字符串中的 old 替换成 new,如果 max 指定,则替换不超过 max 次。
rfind(str, beg=0,end=len(string))
类似于 find()函数,不过是从右边开始查找.
rindex( str, beg=0, end=len(string))
类似于 index(),不过是从右边开始.
rjust(width,[, fillchar])
返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串
rstrip()
删除字符串字符串末尾的空格.
split(str="", num=string.count(str))
以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num+1 个子字符串
splitlines([keepends])
按照行('r', 'rn', n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
startswith(substr, beg=0,end=len(string))
检查字符串是否是以指定子字符串 substr 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。
strip([chars])
在字符串上执行 lstrip()和 rstrip()
swapcase()
将字符串中大写转换为小写,小写转换为大写
title()
返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
translate(table, deletechars="")
根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中
upper()
转换字符串中的小写字母为大写
zfill (width)
返回长度为 width 的字符串,原字符串右对齐,前面填充0
isdecimal()
检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。

'1.字符串常量集合'
import string

print(string.ascii_uppercase) #大写字母
print(string.ascii_lowercase) #小写字母
print(string.ascii_letters) #大小写字母
print(string.digits) #数字
print(string.punctuation) #符号集合
print(string.printable) #可输入字符合集,包括大小写字母数字和符号的合集

'2.字符串大小写转换 5个'
str='hello,woRld!'
print(str.capitalize()) #仅首字母大写,Hello,world!
print(str.title()) #仅每个单词首字母大写,Hello,World!
print(str.upper()) #每个字母都大写,HELLO,WORLD!
print(str.lower()) #每个字母都小写,hello,world!
print(str.swapcase()) #大小写互换,HELLO,WOrLD!

'3.字符串内容判断 10个'
num='123'
alp='asd'
num_alp='a1s2d'
printable='`~!@#$%'
print(num.isdigit()) #字符串中的字符是否都是数字,True
print(alp.isalpha()) #字符串中的字符是否都是字母,True
print(num_alp.isalnum()) #字符串中的字符是否都是字母和数字,True
print(printable.isprintable()) #字符串中的字符是否都是可输入字符,True
print(num.isnumeric()) #字符串中的字符是否都是数字,True
print(alp.islower()) #字符串中的字符是否都是小写字母,True
print(num_alp.isupper()) #字符串中的字符是否都是大写字母,False
print(alp.istitle()) #字符串中的字符是形如标题Hello World,False
print(' '.isspace()) #字符串中的字符是否都是空格,True
print('哈'.isascii()) #字符串中的字符是否可用ascll码表示,汉字是Unicode编码表示的所以是False

'4.字符串填充'
str='Welcome'
print(str.center(13,'*'))#Welcome
print(str.ljust(10,'+')) #Welcome+++
print(str.rjust(10,'-')) #---Welcome
print(str.zfill(10)) #000Welcome
print('-100'.zfill(10)) #-000000100
print('+100'.zfill(10)) #+000000100

'5.字符串搜索'
str='awasdhiwhhihuasd~hjdsasdihfi'
print(str.index('asd')) #str中有子字符串时回返回收自费所在索引值,若不存在则报错
try:

print(str.index('aes'))

except ValueError as v:

print(v)

print(str.find('asd')) #str中有子字符串时会返回首字母所在索引值,若不存在则返回-1
print(str.find('aes'))
print(str.count('asd')) #返回字符串中包含的子串个数
print(str.count('aes')) #不存在则返回0

'6.字符串替换'
str='hello,world!'
print(str.replace('world','python')) #生成替换字符的复制,hello,python!原字符串str未改变
print(str) #hello,world!
str='awasdhiwhhihuasd~hjdsasdihfi'
print(str.replace('asd','ASD',2)) #awASDhiwhhihuASD~hjdsasdihfi

'7.字符串添加'

join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串

用法:str.join(sequence),sequence包括字符串、列表、元祖、集合及字典(字典仅连接key),其中列表、元祖和集合的元素都必须是字符串,否则会报错

lis=['I','am','IronMan!']
print(' '.join(lis)) #I am IronMan!
print('*'.join({'1','2'}))
print('-'.join('ABCD'))
print('+'.join(('a','b','c')))
print('~'.join({'a':1,'b':2}))

'8.字符串修剪'
b="qq-qeasdzxcrtqwe----"
print(b.strip('q')) #-qeasdzxcrtqwe----

'9.字符串切割'
b="this is string example"
print(b.split(' ')) #以空格为分割符进行切片 ['this', 'is', 'string']

'9.字符串切割'
'''
partition(sep)对给定字符串进行切割,切割成三部分
首先搜索到字符串sep,将sep之前的部分为一部分,sep本身作为一部分,剩下作为一部分

partition()与rpartition()之间十分相似,主要不同体现在当字符串中没有指定sep时
partition()分为三部分,字符串、空白、空白
rpartition()分为三部分,空白、空白、字符串'''
test='haoiugdsgfasdhreiuufufg'
print(test.partition('asd')) #('haoiugdsgf', 'asd', 'hreiuufufg')
print(test.partition(' nji'))#('haoiugdsgfasdhreiuufufg', '', '')
print(test.rpartition('njj'))#('', '', 'haoiugdsgfasdhreiuufufg')

4.格式化字符串

格式化字符串可以很好的帮助我们把我们想要的输出出来,用起来也很方便,主要有下面几种形式。

1

2

3

4

5

6

7

#格式化字符串

print`('hello,{0} {1} {2}'.format('zhong', 'yuan',` `'gong')) #通过位置格式化`

print`('hello,{name},my name is {self}!!'.format(name='tom',` `self='sir')) #通过key填充`

l`=['tom',` `'sir']`

print`('hello,{l[0]},my name is {l[1]}!!'.format(l=l)) #通过数组的下标填充`

m`={'name':` `'tom', 'self':` `'sir'}`

print`('hello,{m[name]},my name is {m[self]}!!'.format(m=m)) #通过字典的key填充,键名不加引号`

上面输出结果都是:hello,tom,my name is sir!!

5。字符串大小写问题

关于英文字符串的大小写转换问题,可以通过下面几个函数实现

1

2

3

4

5

6

7

8

9

#首字母大写

a = 'hello,zHong yUan GoNg!!'

print`(a.title())`

#全部大写

print`(a.upper())`

#全部小写

print`(a.lower())`

#首个单词的首字母大写

print`(a.capitalize())`

 输出结果一次为:

Hello,Zhong Yuan Gong!!
HELLO,ZHONG YUAN GONG!!
hello,zhong yuan gong!!
Hello,zhong yuan gong!!

字符串切片

1

2

3

4

5

6

7

d = '123456789'

#获取第3到6个字符

print`(d[2:6]) #这里输入的是字符串的下标,python中切片时,含前不含后,就如这里输出的是下标2-5的子字符串,而不是下标2-6的子字符串。`

#获取最后2个字符

print`(d[-2`:])

#对字符串进行反转

print`(d[::-1`])

 输出结果如下:

3456
89
987654321

6.删除字符串中的空格

1

2

3

4

5

6

7

8

9

c = '   hello world !!!     '

#去掉字符串开头和末尾的空格

print`(c.strip())`

#去掉字符串左边的空格

print`(c.lstrip())`

#去掉字符串右边的空格

print`(c.rstrip())`

#去掉字符串中所有的空格

print`(c.replace(' ',''))`

输出依次为:

hello world !!!
hello world !!!     
   hello world !!!
helloworld!!!

注意:这里不要把strip函数和split函数搞混了,前者是删除字符串中指定的字符,默认为空格,后者是用指定的字符分割字符串,默认也是空格

0x05:更改字符串的编码

有时候我们在进行文件存储是,会出现乱码,这时候,我们改一下编码就OK了。方式如下

1

2

3

#转换字符串编码

e`=`'hello,zhongyuan university,你很好!'

print`(e.encode('utf-8'))`

你可能感兴趣的