python基础字符串处理

Posted ops_sylar

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python基础字符串处理相关的知识,希望对你有一定的参考价值。

字符串处理

msg = ‘my name is sylar‘

capitalize方法,将字符串的首字母大写

print ‘capitalize方法:‘, msg.capitalize()

swapcase方法用于对字符串的大小写字母进行转换。upper

print ‘swapcase方法:‘, msg.swapcase()
print ‘upper方法:‘,msg.upper()
msq_lower = msg.upper()
print ‘lower方法:‘,msq_lower, msq_lower.lower()

所有单词都是以大写开始,其余字母均为小写(见 istitle())

print ‘title方法:‘,msg.title()

count方法,查询子串出现的次数

print msg.count(‘name‘)
print ‘count方法:‘, msg.count(‘a‘)

center:用指定的字符,将字符串填充到指定的长度左

print ‘center方法:‘, msg.center(40,‘x‘)

ljust将原字符串左对齐,并使用空格填充至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符.填充字符,默认为空格。

print ‘ljust方法:‘, msg.ljust(20,‘x‘)

rjust将原字符串右对齐,并使用空格填充至长度 width 的新字符串。如果指定的长度小于字符串的长度则返回原字符串。

print ‘rjust方法:‘, msg.rjust(20,‘x‘)

字符编码 #decode,encode

msg2 = ‘我是sylar‘
msg3 = u‘我是sylar‘
print ‘msg2:‘,msg2,type(msg2),‘\tmsg3:‘, msg3, type(msg3)
msg2 = msg2.decode(‘utf-8‘)
msg3 = msg3.encode(‘utf8‘)
print ‘msg2.decode:‘,msg2, type(msg2), ‘\tmsg3.decode:‘,msg3,type(msg3)

endswith,startswith 查找字符串的开始和结束位置的字符串

print msg.endswith(‘sylar‘)
print msg.endswith(‘tom‘)
print msg.startswith(‘my‘)
print msg.startswith(‘MY‘)

expandtabs 将制表符TAB替换为空格 windows这里不太明显.Linux下面是改变制表符的长度

msg_expandtabs = ‘my name is\tsylar‘
print ‘expandtabs方法:‘,msg.expandtabs()

fing,index方法 #index检查是否包含一个子串位置码和find方法一样,但是会报告一个错误返回!,find方法不会返回错误返回-1

print ‘index方法:‘,msg.index(‘y‘)

print ‘index方法返回错误:‘,msg.index(‘sylra‘)

print ‘find方法:‘,msg.find(‘y‘)
print ‘find方法没找到:‘,msg.find(‘tom‘)

rfind,rindex返回字符串最后一次出现的位置 find,index是第一次出现的位置

print ‘rfind方法:‘,msg.rfind(‘y‘)
print ‘rindex方法:‘,msg.rindex(‘y‘)

format 格式化输出字符串

msg.format()
age = ‘88‘
name = ‘sylar‘
print(‘{0} is {1} years old. ‘.format(name, age)) #输出参数
print(‘{0} is a girl. ‘.format(name))

字符串类型判断

age_num = age.isalnum() #所有字符都是数字或者字母
age_dig = age.isdigit() #所有字符都是数字
age_alp = age.isalpha() #所有字符都是字母
age_low = age.islower() #所有字符都是小写
age_spc = age.isspace() #所有字符都是空白字符
age_tit = age.istitle() #所有单词都是首字母大写,像标题
age_upp = age.isupper() #所有字符都是大写
print ‘字符串类型判断:‘,age_num,age_dig,age_alp,age_low,age_spc,age_tit,age_upp

lstrip方法用于 截掉字符串左边的空格或指定字符。rstrip 删除 string 字符串末尾的指定字符,

strip方法用于移除字符串头尾指定的字符(默认为空格)

msg_strip = ‘xxxkslfsjflsjxxx‘
print ‘lstrip方法:‘, msg_strip.lstrip(‘x‘)
print ‘rstrip方法:‘,msg_strip.rstrip(‘x‘)
print ‘strip方法:‘,msg_strip.strip(‘x‘)

截取指定长度的字符串,原字符串右对齐,前面填充0

print ‘zfill方法:‘,msg.zfill(10)

replace方法 替换字符串中的字符串,如果指定第三个参数count,则替换不超过 count 次

print ‘replace方法‘,msg.replace(‘is‘,‘\033[31;1mis\033[0m‘)
print ‘replace方法‘,msg.replace(‘is‘,‘\033[31;1m%s\033[0m‘%name)

join将序列中的元素以指定的字符连接生成一个新的字符串

join_list = [‘1‘,‘2‘,‘3‘,‘4‘]
msg_join =‘‘.join(join_list)
print ‘join方法:‘, msg_join ,type(msg_join)

split,rsplit 将字符串格式化为列表,不指定切割字符默认为空格,还可以指定切割次数,split 从左往右,rsplit从右向左(默认为空格)

msg_spt = msg.split(‘y‘,1)
print msg_spt,type(msg_spt),msg_spt[0] #当列表内有中文是,直接打印列表返回Unicode编码,取值时则返回中文
msg_spt = msg.rsplit(‘y‘,1)
print msg_spt,type(msg_spt),msg_spt[0]

partition 方法 将字符串划为元祖 根据指定的分隔符将字符串进行分割。

print ‘partition方法:‘, msg.partition(‘y‘), type(msg.partition(‘y‘))
print ‘rpartition方法:‘, msg.rpartition(‘y‘),type(msg.rpartition(‘y‘))

splitlines按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行

msg_splitlines=‘1\n2\n3\n4‘
print ‘splitlines‘,msg_splitlines.splitlines()

translate()根据参数table给出的表(包含 256 个字符)转换字符串的字符, 要过滤掉的字符放到 del 参数中。

以上是关于python基础字符串处理的主要内容,如果未能解决你的问题,请参考以下文章

在 Python 多处理进程中运行较慢的 OpenCV 代码片段

python常用代码片段总结

你如何在 python 中处理 graphql 查询和片段?

python基础学习--字符串和文件数据处理--附代码

常用python日期日志获取内容循环的代码片段

《Python学习之路 -- Python基础之切片》