龙空技术网

Python语法速查:字符串格式简单处理、子串查找与判断方法?

最爱脆啵啵 143

前言:

现在我们对“python判断字符串不相等”大概比较讲究,姐妹们都想要知道一些“python判断字符串不相等”的相关知识。那么小编也在网摘上网罗了一些有关“python判断字符串不相等””的相关内容,希望大家能喜欢,小伙伴们快快来了解一下吧!

这是一篇python基础知识分享型文章,对学习python感兴趣的朋友们可以仔细看看,其他朋友则可以猜一下,本篇文章小编用了几个表情包?不能耍赖哦!

字符串常用方法

Python3中,字符串全都用Unicode形式,所以省去了很多以前各种转换与声明的麻烦。字符串属于序列,所有序列可用的方法(比如切片等)都可用于字符串。

注意:字符串属于不可变序列,所有处理修改字符的方法,都会生成一个新字符串返回,原字符串不会变。

字符串方法简述举例或说明

字符串内容检查

s.isalpha()是否所有字符都为字母'abc'.isalpha() # 结果为 True

s.islower()字符串中字母是否都为小写(无视其中的非字母字符)'abc'.islower() # 结果为 True

s.isupper()字符串中字母是否都为大写(无视其中的非字母字符)'ABC'.isupper() # 结果为 True

s.isdecimal()是否所有字符都为数字0~9(小数点和正负号视作非数字)'123'.isdedimal() # 结果为 True

s.isdigit()是否所有字符都为:数字0~9、罗马数字(小数点和正负号视作非数字)'Ⅳ'.isdigit() # 结果为 True

s.isnumeric()是否所有字符都为:数字0~9、罗马数字、汉字数字(小数点和正负号视作非数字)'一百'.isnumeric() # 结果为 True

s.isalnum()是否所有字符都为字母或数字'abc123'.isalnum() # 结果为 True

s.isspace()是否所有字符都为空白' \t '.isspace() # 结果为 True

s.isprintable()是否所有字符都可打印。'a\t'.isprintable() # 结果为 False

s.isascii()是否所有字符都为ascii码范围内字符'a1#'.isascii() # 结果为 True

s.istitle()是否字符串中每个单词首字母都为大写(若单词首字符为非字母字符,则判断第2个字符,以此类推)'Ab 2Cc'.istitle() # 结果为 True

s.isidentifier()字符串内容是否为Python保留字'if'.isidentifier() # 结果为 True

子串查找与判断

s.startswith(prefix [,start [,end]])检查字符串是否以prefix开头,start, end为查找范围(用法同切片)。'abc'.startswith('ab') # 结果为 True

s.endswith(suffix [,start [,end]])检查字符串是否以suffix结尾,start, end为查找范围(用法同切片)。'abc'.endswith('b') # 结果为 False

'abc'.endswith('b',0,2) # 结果为 True

s.find(sub [,start [,end]])查找指定字符串sub首次出现的位置,若没找到则返回-1。start, end为查找范围(用法同切片)。'abcabc'.find('bc') # 结果为 1

s.rfind(sub [,start [,end]])查找指定字符串sub最后一次出现的位置,若没找到则返回-1,start, end用法同上。'abcabc'.rfind('bc') # 结果为 4

s.index(sub [,start [,end]])功能同s.find(),区别是没找到时引发ValueError错误。'abcabc'.index('bc') # 结果为 1

s.rindex(sub [,start [,end]])功能同s.rfind(),区别是没找到时引发ValueError错误。'abcabc'.index('bc') # 结果为 4

s.count(sub [,start [,end]])统计指定子字符串sub出现的次数,start和end为查找范围(用法同切片)。'abc'.count('b',1,1) # 结果为 0

'abc'.count('b',1,2) # 结果为 1

字符串修改

s.lower()返回新字符串,内容为将原字符串中字母全转成小写(非字母字符则不变)'A1B2'.lower() # 返回为 'a1b2'

s.upper()返回新字符串,内容为将原字符串中字母全转成大写(非字母字符则不变)'a1b2'.upper() # 返回为 'A1B2'

s.swapcase()返回新字符串,内容为将原字符串中字母大小写互换(非字母字符则不变)'abCD'.swapcase() # 返回为 'ABcd'

s.capitalize()返回新字符串,内容为将原字符串中每个单词的首字母变为大写。'ab cd'.capitalize()

# 返回为 'Ab Cd;

s.expandtabs(tabsize=8)返回新字符串,内容用空格替换制表符,入参为tab对应的空格数。a\tb'.expandtabs(4)

# 返回为 'a b'

s.replace(old, new [,count])返回新字符串,内容为用new替换原字符串中old内容,count可指定替换次数(默认为全部替换)'abcdab'.replace('ab','xy')

# 返回为 'xycdxy'

字符串格式简单处理

s.strip([chars])返回新字符串,内容为删掉原字符串中两边的空白。若指定入参chars,则为删掉原字符串两端在入参chars中出现的字符。' abc '.strip() # 返回为 'abc'

''.strip('.cwom')

# 返回为 'xyz'

s.lstrip([chars])用法同上,不过仅处理字符串的左边。''.lstrip('.cwom')

# 返回为 'xyz.com'

s.rstrip([chars])用法同上,不过仅处理字符串的右边。''.rstrip('.cwom')

# 返回为 '

s.center(width [,fillchar])返回新字符串,在长度为width的宽度内将原字符串居中,fillchar为填充单字符'abc'.center(9,'*')

# 返回为 '***abc***'

s.ljust(width [,fillchar])返回新字符串,在长度为width的宽度内将原字符串靠左对齐,fillchar为填充单字符'abc'.ljust(9,'*')

# 返回为 'abc******'

s.rjust(width [,fillchar])返回新字符串,在长度为width的宽度内将原字符串靠右对齐,fillchar为填充单字符'abc'.rjust(9,'*')

# 返回为 '******abc'

s.zfill(width)返回新字符串,在原字符串左边填充0,直至其宽度为width'abc'.zfill(9)

# 返回为 '000000abc'

s.translate(table)字符映射转换。使用一个转换表table,将字符串中的某个子串映射成另一个子串。转换table由下面的maketrans()方法生成。t=str.maketrans({'ab':'cd'})

'abc'.translate(t)

# 返回为 'cdc'

t2=str.maketrans('ab','xy')

'abc'.translate(t2)

# 返回为 'xyc'

t3=str.maketrans('ab','xy',c)

'abc'.translate(t3)

# 返回为 'xy'

s.maketrans(x [,y [,z]])静态方法。生成一个供上面translate()方法是用的转换表,其中原始子串和映射后子串必须长度相同。若只提供一个参数:x必须为一个字典,键名表示原始子串,值表示映射后子串。若提供2个参数:x表示原始子串,y表示映射后子串。若提供3个参数:x, y含义不变,z表示要删除的子串。

完整字符串格式化方法

s.format(*args, **kwargs)字符串格式化方法用法详见“字符串格式化”篇

s.format_map(mapping)Python3.2新增方法,可以直接使用字典作为输入参数进行字符串格式化。比较:format()与format_map()

'Hi {name}!'.format(name='Tom')

# 结果为 'Hi Tom!'

d={'name':'Tom'}

'Hi {name}!'.format_map(d)

# 结果为 'Hi Tom!'

字符串分割与拼接

s.split(sep=None, maxsplit=-1)将字符串以sep作为分隔符进行划分,将划分后的每个片段子串排成一个列表返回。maxsplit是划分的最大次数(默认-1为不设上限)。若在字符串中没找到指定分隔符,则将原字符串作为单一元素放入列表。'a,b,c'.split(',')

# 结果为 ['a','b','c']

s.rsplit(sep=None, maxsplit=-1)用法同上,只不过是从右边开始划分字符串,列表中内容的顺序仍旧为从左到右。详见右例。'a,b,c'.rsplit(',',maxsplit=1)

# 结果为 ['a,b','c']

'a,b,c'.rsplit(',')

# 结果仍为 ['a','b','c']

splitlines([keepends])将多行字符串按行进行分隔成列表,若参数keepends为True,则保留每行后的换行符。x="""a

b"""

x.splitlines()

# 结果为 ['a','b']

x.splitlines(True)

# 结果为 ['a\n','b']

s.partition(sep)用分隔符字符串sep划分字符串,返回一个元祖(head, sep, tail)。若没找到sep,则返回(s, "", "")'a;b;c'.partition(';')

# 结果为 ('a', ';', 'b;c')

s.rpartition(sep)用法同上,只不过是从右边开始划分字符串,详见右例。'a;b;c'.rpartition(';')

# 结果为 ('a;b', ';', 'c')

s.join(iter)用s作为分隔符,将iter中所有迭代对象拼接成一个字符串返回。';'.join('abc')

# 结果为 'a;b;c'

';'.join(['ab','cd'])

# 结果为 'ab;cd'

字符串编码

s.encoding(encoding="utf-8", errors="sctrict")返回字符串的编码后字节流版本,返回类型为bytes。默认为严格检错模式,只要在转换过程中发现错误,即引发UnicodeError错误。常用的encoding参数:

'ascii'、'utf-16'、'utf-32'、

'gb2312'(国标)、

'gbk' (gb2312的超集)

有几个表情包呢?觉得文章还不错的话不妨收藏起来慢慢看,有任何建议或看法欢迎大家在评论区分享讨论!

我是一名python开发工程师,整理了一套python的学习资料,如果你想提升自己,对编程感兴趣,关注我并在后台私信小编:“08”即可免费领取资料!希望对你能有所帮助!

标签: #python判断字符串不相等