0

0

Python 字符串操作方法大全

巴扎黑

巴扎黑

发布时间:2016-12-19 13:57:00

|

1351人浏览过

|

来源于php中文网

原创

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换、删除、截取、复制、连接、比较、查找、分割等,需要的朋友可以参考下 


1、去空格及特殊符号 


复制代码 代码如下: 

s.strip().lstrip().rstrip(',') 

2、复制字符串 

复制代码 代码如下: 

#strcpy(sstr1,sstr2) 
sstr1 = 'strcpy' 
sstr2 = sstr1 
sstr1 = 'strcpy2' 
print sstr2 

3、连接字符串 

复制代码 代码如下: 

#strcat(sstr1,sstr2) 
sstr1 = 'strcat' 
sstr2 = 'append' 
sstr1 += sstr2 
print sstr1 

4、查找字符 

复制代码 代码如下: 

#strchr(sstr1,sstr2) 
# sstr1 = 'strchr' 
sstr2 = 's' 
npos = sstr1.index(sstr2) 
print npos 

5、比较字符串 

复制代码 代码如下: 

#strcmp(sstr1,sstr2) 
sstr1 = 'strchr' 
sstr2 = 'strch' 
print cmp(sstr1,sstr2) 

6、扫描字符串是否包含指定的字符 

复制代码 代码如下: 

#strspn(sstr1,sstr2) 
sstr1 = '12345678' 
sstr2 = '456' 
#sstr1 and chars both in sstr1 and sstr2 
print len(sstr1 and sstr2) 

7、字符串长度 

复制代码 代码如下: 

#strlen(sstr1) 
sstr1 = 'strlen' 
print len(sstr1) 

8、将字符串中的大小写转换 

复制代码 代码如下: 

s.lower() #小写 
s.upper() #大写 
s.swapcase() #大小写互换 
s.capitalize() #首字母大写 
string.capwords(s) #这是模块中的方法。它把s用split()函数分开,然后用capitalize()把首字母变成大写,最后用join()合并到一起 
#实例: 
#strlwr(sstr1) 
sstr1 = 'jcstrlwr' 
sstr1 = sstr1.upper() 
#sstr1 = sstr1.lower() 
print sstr1 


9、追加指定长度的字符串 

复制代码 代码如下: 

#strncat(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = 'abcdef' 
n = 3 
sstr1 += sstr2[0:n] 
print sstr1 

10、字符串指定长度比较 

复制代码 代码如下: 

#strncmp(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = '123bc' 
n = 3 
print cmp(sstr1[0:n],sstr2[0:n]) 

11、复制指定长度的字符 

复制代码 代码如下: 

#strncpy(sstr1,sstr2,n) 
sstr1 = '' 
sstr2 = '12345' 
n = 3 
sstr1 = sstr2[0:n] 
print sstr1 

12、将字符串前n个字符替换为指定的字符 

复制代码 代码如下: 

#strnset(sstr1,ch,n) 
sstr1 = '12345' 
ch = 'r' 
n = 3 
sstr1 = n * ch + sstr1[3:] 
print sstr1 

13、扫描字符串 

复制代码 代码如下: 

#strpbrk(sstr1,sstr2) 
sstr1 = 'cekjgdklab' 
sstr2 = 'gka' 
npos = -1 
for c in sstr1: 
    if c in sstr2: 
        npos = sstr1.index(c) 
        break 
print npos 

14、翻转字符串 

复制代码 代码如下: 

#strrev(sstr1) 
sstr1 = 'abcdefg' 
sstr1 = sstr1[::-1] 
print sstr1 

15、查找字符串 

复制代码 代码如下: 

#strstr(sstr1,sstr2) 
sstr1 = 'abcdefg' 
sstr2 = 'cde' 
print sstr1.find(sstr2) 

16、分割字符串 

复制代码 代码如下: 

#strtok(sstr1,sstr2) 
sstr1 = 'ab,cde,fgh,ijk' 
sstr2 = ',' 
sstr1 = sstr1[sstr1.find(sstr2) + 1:] 
print sstr1 
#或者 
s = 'ab,cde,fgh,ijk' 
print(s.split(',')) 

17、连接字符串 

复制代码 代码如下: 

delimiter = ',' 
mylist = ['brazil', 'russia', 'india', 'china'] 
print delimiter.join(mylist) 

18、php 中 addslashes 的实现 

复制代码 代码如下: 

def addslashes(s): 
    d = {'"':'"', "'":"'", "

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换、删除、截取、复制、连接、比较、查找、分割等,需要的朋友可以参考下 


1、去空格及特殊符号 


复制代码 代码如下: 

s.strip().lstrip().rstrip(',') 

2、复制字符串 

复制代码 代码如下: 

#strcpy(sstr1,sstr2) 
sstr1 = 'strcpy' 
sstr2 = sstr1 
sstr1 = 'strcpy2' 
print sstr2 

3、连接字符串 

复制代码 代码如下: 

#strcat(sstr1,sstr2) 
sstr1 = 'strcat' 
sstr2 = 'append' 
sstr1 += sstr2 
print sstr1 

4、查找字符 

复制代码 代码如下: 

#strchr(sstr1,sstr2) 
# sstr1 = 'strchr' 
sstr2 = 's' 
npos = sstr1.index(sstr2) 
print npos 

5、比较字符串 

复制代码 代码如下: 

#strcmp(sstr1,sstr2) 
sstr1 = 'strchr' 
sstr2 = 'strch' 
print cmp(sstr1,sstr2) 

6、扫描字符串是否包含指定的字符 

复制代码 代码如下: 

#strspn(sstr1,sstr2) 
sstr1 = '12345678' 
sstr2 = '456' 
#sstr1 and chars both in sstr1 and sstr2 
print len(sstr1 and sstr2) 

7、字符串长度 

复制代码 代码如下: 

#strlen(sstr1) 
sstr1 = 'strlen' 
print len(sstr1) 

8、将字符串中的大小写转换 

复制代码 代码如下: 

s.lower() #小写 
s.upper() #大写 
s.swapcase() #大小写互换 
s.capitalize() #首字母大写 
string.capwords(s) #这是模块中的方法。它把s用split()函数分开,然后用capitalize()把首字母变成大写,最后用join()合并到一起 
#实例: 
#strlwr(sstr1) 
sstr1 = 'jcstrlwr' 
sstr1 = sstr1.upper() 
#sstr1 = sstr1.lower() 
print sstr1 


9、追加指定长度的字符串 

复制代码 代码如下: 

#strncat(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = 'abcdef' 
n = 3 
sstr1 += sstr2[0:n] 
print sstr1 

10、字符串指定长度比较 

复制代码 代码如下: 

#strncmp(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = '123bc' 
n = 3 
print cmp(sstr1[0:n],sstr2[0:n]) 

11、复制指定长度的字符 

复制代码 代码如下: 

#strncpy(sstr1,sstr2,n) 
sstr1 = '' 
sstr2 = '12345' 
n = 3 
sstr1 = sstr2[0:n] 
print sstr1 

12、将字符串前n个字符替换为指定的字符 

复制代码 代码如下: 

#strnset(sstr1,ch,n) 
sstr1 = '12345' 
ch = 'r' 
n = 3 
sstr1 = n * ch + sstr1[3:] 
print sstr1 

13、扫描字符串 

复制代码 代码如下: 

#strpbrk(sstr1,sstr2) 
sstr1 = 'cekjgdklab' 
sstr2 = 'gka' 
npos = -1 
for c in sstr1: 
    if c in sstr2: 
        npos = sstr1.index(c) 
        break 
print npos 

14、翻转字符串 

复制代码 代码如下: 

#strrev(sstr1) 
sstr1 = 'abcdefg' 
sstr1 = sstr1[::-1] 
print sstr1 

15、查找字符串 

复制代码 代码如下: 

#strstr(sstr1,sstr2) 
sstr1 = 'abcdefg' 
sstr2 = 'cde' 
print sstr1.find(sstr2) 

16、分割字符串 

复制代码 代码如下: 

#strtok(sstr1,sstr2) 
sstr1 = 'ab,cde,fgh,ijk' 
sstr2 = ',' 
sstr1 = sstr1[sstr1.find(sstr2) + 1:] 
print sstr1 
#或者 
s = 'ab,cde,fgh,ijk' 
print(s.split(',')) 

17、连接字符串 

复制代码 代码如下: 

delimiter = ',' 
mylist = ['brazil', 'russia', 'india', 'china'] 
print delimiter.join(mylist) 

18、php 中 addslashes 的实现 

复制代码 代码如下: 

def addslashes(s): 
    d = {'"':'\"', "'":"\'", "":"\", "\":"\\"} 
    return ''.join(d.get(c, c) for c in s) 

s = "john 'johny' doe (a.k.a. "super joe")\" 
print s 
print addslashes(s) 

19、只显示字母与数字 

复制代码 代码如下: 

def onlycharnum(s,oth=''): 
    s2 = s.lower(); 
    fomart = 'abcdefghijklmnopqrstuvwxyz0123456789' 
    for c in s2: 
        if not c in fomart: 
            s = s.replace(c,''); 
    return s; 

print(onlystr("a000 aa-b")) 


20、截取字符串 

复制代码 代码如下: 

str = '0123456789′ 
print str[0:3] #截取第一位到第三位的字符 
print str[:] #截取字符串的全部字符 
print str[6:] #截取第七个字符到结尾 
print str[:-3] #截取从头开始到倒数第三个字符之前 
print str[2] #截取第三个字符 
print str[-1] #截取倒数第一个字符 
print str[::-1] #创造一个与原字符串顺序相反的字符串 
print str[-3:-1] #截取倒数第三位与倒数第一位之前的字符 
print str[-3:] #截取倒数第三位到结尾 
print str[:-5:-3] #逆序截取,具体啥意思没搞明白? 

21、字符串在输出时的对齐 

复制代码 代码如下: 

s.ljust(width,[fillchar]) 
#输出width个字符,s左对齐,不足部分用fillchar填充,默认的为空格。 
s.rjust(width,[fillchar]) #右对齐 
s.center(width, [fillchar]) #中间对齐 
s.zfill(width) #把s变成width长,并在右对齐,不足部分用0补足 

22、字符串中的搜索和替换 

复制代码 代码如下: 

s.find(substr, [start, [end]]) 
#返回s中出现substr的第一个字母的标号,如果s中没有substr则返回-1。start和end作用就相当于在s[start:end]中搜索 
s.index(substr, [start, [end]]) 
#与find()相同,只是在s中没有substr时,会返回一个运行时错误 
s.rfind(substr, [start, [end]]) 
#返回s中最后出现的substr的第一个字母的标号,如果s中没有substr则返回-1,也就是说从右边算起的第一次出现的substr的首字母标号 
s.rindex(substr, [start, [end]]) 
s.count(substr, [start, [end]]) #计算substr在s中出现的次数 
s.replace(oldstr, newstr, [count]) 
#把s中的oldstar替换为newstr,count为替换次数。这是替换的通用形式,还有一些函数进行特殊字符的替换 
s.strip([chars]) 
#把s中前后chars中有的字符全部去掉,可以理解为把s前后chars替换为none 
s.lstrip([chars]) 
s.rstrip([chars]) 
s.expandtabs([tabsize]) 
#把s中的tab字符替换没空格,每个tab替换为tabsize个空格,默认是8个 

23、字符串的分割和组合 

复制代码 代码如下: 

s.split([sep, [maxsplit]]) 
#以sep为分隔符,把s分成一个list。maxsplit表示分割的次数。默认的分割符为空白字符 
s.rsplit([sep, [maxsplit]]) 
s.splitlines([keepends]) 
#把s按照行分割符分为一个list,keepends是一个bool值,如果为真每行后而会保留行分割符。 
s.join(seq) #把seq代表的序列──字符串序列,用s连接起来 

24、字符串的mapping,这一功能包含两个函数 

复制代码 代码如下: 

string.maketrans(from, to) 
#返回一个256个字符组成的翻译表,其中from中的字符被一一对应地转换成to,所以from和to必须是等长的。 
s.translate(table[,deletechars]) 
# 使用上面的函数产后的翻译表,把s进行翻译,并把deletechars中有的字符删掉。需要注意的是,如果s为unicode字符串,那么就不支持 deletechars参数,可以使用把某个字符翻译为none的方式实现相同的功能。此外还可以使用codecs模块的功能来创建更加功能强大的翻译表。 

25、字符串还有一对编码和解码的函数 

复制代码 代码如下: 

s.encode([encoding,[errors]]) 
# 其中encoding可以有多种值,比如gb2312 gbk gb18030 bz2 zlib big5 bzse64等都支持。errors默认值为"strict",意思是unicodeerror。可能的值还有'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 和所有的通过codecs.register_error注册的值。这一部分内容涉及codecs模块,不是特明白 
s.decode([encoding,[errors]]) 

26、字符串的测试、判断函数,这一类函数在string模块中没有,这些函数返回的都是bool值 

复制代码 代码如下: 

s.startswith(prefix[,start[,end]]) 
#是否以prefix开头 
s.endswith(suffix[,start[,end]]) 
#以suffix结尾 
s.isalnum() 
#是否全是字母和数字,并至少有一个字符 
s.isalpha() #是否全是字母,并至少有一个字符 
s.isdigit() #是否全是数字,并至少有一个字符 
s.isspace() #是否全是空白字符,并至少有一个字符 
s.islower() #s中的字母是否全是小写 
s.isupper() #s中的字母是否便是大写 
s.istitle() #s是否是首字母大写的 

27、字符串类型转换函数,这几个函数只在string模块中有 

复制代码 代码如下: 

string.atoi(s[,base]) 
#base默认为10,如果为0,那么s就可以是012或0x23这种形式的字符串,如果是16那么s就只能是0x23或0x12这种形式的字符串 
string.atol(s[,base]) #转成long 
string.atof(s[,base]) #转成float 


这里再强调一次,字符串对象是不可改变的,也就是说在python创建一个字符串后,你不能把这个字符中的某一部分改变。任何上面的函数改变了字符串后,都会返回一个新的字符串,原字串并没有变。其实这也是有变通的办法的,可以用s=list(s)这个函数把s变为由单个字符为成员的list,这样的话就可以使用s[3]='a'的方式改变值,然后再使用s=" ".join(s)还原成字符串

":"

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换、删除、截取、复制、连接、比较、查找、分割等,需要的朋友可以参考下 


1、去空格及特殊符号 


复制代码 代码如下: 

s.strip().lstrip().rstrip(',') 

2、复制字符串 

复制代码 代码如下: 

#strcpy(sstr1,sstr2) 
sstr1 = 'strcpy' 
sstr2 = sstr1 
sstr1 = 'strcpy2' 
print sstr2 

3、连接字符串 

复制代码 代码如下: 

#strcat(sstr1,sstr2) 
sstr1 = 'strcat' 
sstr2 = 'append' 
sstr1 += sstr2 
print sstr1 

4、查找字符 

复制代码 代码如下: 

#strchr(sstr1,sstr2) 
# sstr1 = 'strchr' 
sstr2 = 's' 
npos = sstr1.index(sstr2) 
print npos 

5、比较字符串 

复制代码 代码如下: 

#strcmp(sstr1,sstr2) 
sstr1 = 'strchr' 
sstr2 = 'strch' 
print cmp(sstr1,sstr2) 

6、扫描字符串是否包含指定的字符 

复制代码 代码如下: 

#strspn(sstr1,sstr2) 
sstr1 = '12345678' 
sstr2 = '456' 
#sstr1 and chars both in sstr1 and sstr2 
print len(sstr1 and sstr2) 

7、字符串长度 

复制代码 代码如下: 

#strlen(sstr1) 
sstr1 = 'strlen' 
print len(sstr1) 

8、将字符串中的大小写转换 

复制代码 代码如下: 

s.lower() #小写 
s.upper() #大写 
s.swapcase() #大小写互换 
s.capitalize() #首字母大写 
string.capwords(s) #这是模块中的方法。它把s用split()函数分开,然后用capitalize()把首字母变成大写,最后用join()合并到一起 
#实例: 
#strlwr(sstr1) 
sstr1 = 'jcstrlwr' 
sstr1 = sstr1.upper() 
#sstr1 = sstr1.lower() 
print sstr1 


9、追加指定长度的字符串 

复制代码 代码如下: 

#strncat(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = 'abcdef' 
n = 3 
sstr1 += sstr2[0:n] 
print sstr1 

10、字符串指定长度比较 

复制代码 代码如下: 

#strncmp(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = '123bc' 
n = 3 
print cmp(sstr1[0:n],sstr2[0:n]) 

11、复制指定长度的字符 

复制代码 代码如下: 

#strncpy(sstr1,sstr2,n) 
sstr1 = '' 
sstr2 = '12345' 
n = 3 
sstr1 = sstr2[0:n] 
print sstr1 

12、将字符串前n个字符替换为指定的字符 

复制代码 代码如下: 

#strnset(sstr1,ch,n) 
sstr1 = '12345' 
ch = 'r' 
n = 3 
sstr1 = n * ch + sstr1[3:] 
print sstr1 

13、扫描字符串 

复制代码 代码如下: 

#strpbrk(sstr1,sstr2) 
sstr1 = 'cekjgdklab' 
sstr2 = 'gka' 
npos = -1 
for c in sstr1: 
    if c in sstr2: 
        npos = sstr1.index(c) 
        break 
print npos 

14、翻转字符串 

复制代码 代码如下: 

#strrev(sstr1) 
sstr1 = 'abcdefg' 
sstr1 = sstr1[::-1] 
print sstr1 

15、查找字符串 

复制代码 代码如下: 

#strstr(sstr1,sstr2) 
sstr1 = 'abcdefg' 
sstr2 = 'cde' 
print sstr1.find(sstr2) 

16、分割字符串 

复制代码 代码如下: 

#strtok(sstr1,sstr2) 
sstr1 = 'ab,cde,fgh,ijk' 
sstr2 = ',' 
sstr1 = sstr1[sstr1.find(sstr2) + 1:] 
print sstr1 
#或者 
s = 'ab,cde,fgh,ijk' 
print(s.split(',')) 

17、连接字符串 

复制代码 代码如下: 

delimiter = ',' 
mylist = ['brazil', 'russia', 'india', 'china'] 
print delimiter.join(mylist) 

18、php 中 addslashes 的实现 

复制代码 代码如下: 

def addslashes(s): 
    d = {'"':'\"', "'":"\'", "":"\", "\":"\\"} 
    return ''.join(d.get(c, c) for c in s) 

s = "john 'johny' doe (a.k.a. "super joe")\" 
print s 
print addslashes(s) 

19、只显示字母与数字 

复制代码 代码如下: 

def onlycharnum(s,oth=''): 
    s2 = s.lower(); 
    fomart = 'abcdefghijklmnopqrstuvwxyz0123456789' 
    for c in s2: 
        if not c in fomart: 
            s = s.replace(c,''); 
    return s; 

print(onlystr("a000 aa-b")) 


20、截取字符串 

复制代码 代码如下: 

str = '0123456789′ 
print str[0:3] #截取第一位到第三位的字符 
print str[:] #截取字符串的全部字符 
print str[6:] #截取第七个字符到结尾 
print str[:-3] #截取从头开始到倒数第三个字符之前 
print str[2] #截取第三个字符 
print str[-1] #截取倒数第一个字符 
print str[::-1] #创造一个与原字符串顺序相反的字符串 
print str[-3:-1] #截取倒数第三位与倒数第一位之前的字符 
print str[-3:] #截取倒数第三位到结尾 
print str[:-5:-3] #逆序截取,具体啥意思没搞明白? 

21、字符串在输出时的对齐 

复制代码 代码如下: 

s.ljust(width,[fillchar]) 
#输出width个字符,s左对齐,不足部分用fillchar填充,默认的为空格。 
s.rjust(width,[fillchar]) #右对齐 
s.center(width, [fillchar]) #中间对齐 
s.zfill(width) #把s变成width长,并在右对齐,不足部分用0补足 

22、字符串中的搜索和替换 

复制代码 代码如下: 

s.find(substr, [start, [end]]) 
#返回s中出现substr的第一个字母的标号,如果s中没有substr则返回-1。start和end作用就相当于在s[start:end]中搜索 
s.index(substr, [start, [end]]) 
#与find()相同,只是在s中没有substr时,会返回一个运行时错误 
s.rfind(substr, [start, [end]]) 
#返回s中最后出现的substr的第一个字母的标号,如果s中没有substr则返回-1,也就是说从右边算起的第一次出现的substr的首字母标号 
s.rindex(substr, [start, [end]]) 
s.count(substr, [start, [end]]) #计算substr在s中出现的次数 
s.replace(oldstr, newstr, [count]) 
#把s中的oldstar替换为newstr,count为替换次数。这是替换的通用形式,还有一些函数进行特殊字符的替换 
s.strip([chars]) 
#把s中前后chars中有的字符全部去掉,可以理解为把s前后chars替换为none 
s.lstrip([chars]) 
s.rstrip([chars]) 
s.expandtabs([tabsize]) 
#把s中的tab字符替换没空格,每个tab替换为tabsize个空格,默认是8个 

23、字符串的分割和组合 

复制代码 代码如下: 

s.split([sep, [maxsplit]]) 
#以sep为分隔符,把s分成一个list。maxsplit表示分割的次数。默认的分割符为空白字符 
s.rsplit([sep, [maxsplit]]) 
s.splitlines([keepends]) 
#把s按照行分割符分为一个list,keepends是一个bool值,如果为真每行后而会保留行分割符。 
s.join(seq) #把seq代表的序列──字符串序列,用s连接起来 

24、字符串的mapping,这一功能包含两个函数 

复制代码 代码如下: 

string.maketrans(from, to) 
#返回一个256个字符组成的翻译表,其中from中的字符被一一对应地转换成to,所以from和to必须是等长的。 
s.translate(table[,deletechars]) 
# 使用上面的函数产后的翻译表,把s进行翻译,并把deletechars中有的字符删掉。需要注意的是,如果s为unicode字符串,那么就不支持 deletechars参数,可以使用把某个字符翻译为none的方式实现相同的功能。此外还可以使用codecs模块的功能来创建更加功能强大的翻译表。 

25、字符串还有一对编码和解码的函数 

复制代码 代码如下: 

s.encode([encoding,[errors]]) 
# 其中encoding可以有多种值,比如gb2312 gbk gb18030 bz2 zlib big5 bzse64等都支持。errors默认值为"strict",意思是unicodeerror。可能的值还有'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 和所有的通过codecs.register_error注册的值。这一部分内容涉及codecs模块,不是特明白 
s.decode([encoding,[errors]]) 

26、字符串的测试、判断函数,这一类函数在string模块中没有,这些函数返回的都是bool值 

复制代码 代码如下: 

s.startswith(prefix[,start[,end]]) 
#是否以prefix开头 
s.endswith(suffix[,start[,end]]) 
#以suffix结尾 
s.isalnum() 
#是否全是字母和数字,并至少有一个字符 
s.isalpha() #是否全是字母,并至少有一个字符 
s.isdigit() #是否全是数字,并至少有一个字符 
s.isspace() #是否全是空白字符,并至少有一个字符 
s.islower() #s中的字母是否全是小写 
s.isupper() #s中的字母是否便是大写 
s.istitle() #s是否是首字母大写的 

27、字符串类型转换函数,这几个函数只在string模块中有 

复制代码 代码如下: 

string.atoi(s[,base]) 
#base默认为10,如果为0,那么s就可以是012或0x23这种形式的字符串,如果是16那么s就只能是0x23或0x12这种形式的字符串 
string.atol(s[,base]) #转成long 
string.atof(s[,base]) #转成float 


这里再强调一次,字符串对象是不可改变的,也就是说在python创建一个字符串后,你不能把这个字符中的某一部分改变。任何上面的函数改变了字符串后,都会返回一个新的字符串,原字串并没有变。其实这也是有变通的办法的,可以用s=list(s)这个函数把s变为由单个字符为成员的list,这样的话就可以使用s[3]='a'的方式改变值,然后再使用s=" ".join(s)还原成字符串

", "":"\"} 
    return ''.join(d.get(c, c) for c in s) 

s = "john 'johny' doe (a.k.a. "super joe")

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换、删除、截取、复制、连接、比较、查找、分割等,需要的朋友可以参考下 


1、去空格及特殊符号 


复制代码 代码如下: 

s.strip().lstrip().rstrip(',') 

2、复制字符串 

复制代码 代码如下: 

#strcpy(sstr1,sstr2) 
sstr1 = 'strcpy' 
sstr2 = sstr1 
sstr1 = 'strcpy2' 
print sstr2 

3、连接字符串 

复制代码 代码如下: 

#strcat(sstr1,sstr2) 
sstr1 = 'strcat' 
sstr2 = 'append' 
sstr1 += sstr2 
print sstr1 

4、查找字符 

复制代码 代码如下: 

#strchr(sstr1,sstr2) 
# sstr1 = 'strchr' 
sstr2 = 's' 
npos = sstr1.index(sstr2) 
print npos 

5、比较字符串 

复制代码 代码如下: 

#strcmp(sstr1,sstr2) 
sstr1 = 'strchr' 
sstr2 = 'strch' 
print cmp(sstr1,sstr2) 

6、扫描字符串是否包含指定的字符 

复制代码 代码如下: 

#strspn(sstr1,sstr2) 
sstr1 = '12345678' 
sstr2 = '456' 
#sstr1 and chars both in sstr1 and sstr2 
print len(sstr1 and sstr2) 

7、字符串长度 

复制代码 代码如下: 

#strlen(sstr1) 
sstr1 = 'strlen' 
print len(sstr1) 

8、将字符串中的大小写转换 

复制代码 代码如下: 

s.lower() #小写 
s.upper() #大写 
s.swapcase() #大小写互换 
s.capitalize() #首字母大写 
string.capwords(s) #这是模块中的方法。它把s用split()函数分开,然后用capitalize()把首字母变成大写,最后用join()合并到一起 
#实例: 
#strlwr(sstr1) 
sstr1 = 'jcstrlwr' 
sstr1 = sstr1.upper() 
#sstr1 = sstr1.lower() 
print sstr1 


9、追加指定长度的字符串 

复制代码 代码如下: 

#strncat(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = 'abcdef' 
n = 3 
sstr1 += sstr2[0:n] 
print sstr1 

10、字符串指定长度比较 

复制代码 代码如下: 

#strncmp(sstr1,sstr2,n) 
sstr1 = '12345' 
sstr2 = '123bc' 
n = 3 
print cmp(sstr1[0:n],sstr2[0:n]) 

11、复制指定长度的字符 

复制代码 代码如下: 

#strncpy(sstr1,sstr2,n) 
sstr1 = '' 
sstr2 = '12345' 
n = 3 
sstr1 = sstr2[0:n] 
print sstr1 

12、将字符串前n个字符替换为指定的字符 

复制代码 代码如下: 

#strnset(sstr1,ch,n) 
sstr1 = '12345' 
ch = 'r' 
n = 3 
sstr1 = n * ch + sstr1[3:] 
print sstr1 

13、扫描字符串 

复制代码 代码如下: 

#strpbrk(sstr1,sstr2) 
sstr1 = 'cekjgdklab' 
sstr2 = 'gka' 
npos = -1 
for c in sstr1: 
    if c in sstr2: 
        npos = sstr1.index(c) 
        break 
print npos 

14、翻转字符串 

复制代码 代码如下: 

#strrev(sstr1) 
sstr1 = 'abcdefg' 
sstr1 = sstr1[::-1] 
print sstr1 

15、查找字符串 

复制代码 代码如下: 

#strstr(sstr1,sstr2) 
sstr1 = 'abcdefg' 
sstr2 = 'cde' 
print sstr1.find(sstr2) 

16、分割字符串 

复制代码 代码如下: 

#strtok(sstr1,sstr2) 
sstr1 = 'ab,cde,fgh,ijk' 
sstr2 = ',' 
sstr1 = sstr1[sstr1.find(sstr2) + 1:] 
print sstr1 
#或者 
s = 'ab,cde,fgh,ijk' 
print(s.split(',')) 

17、连接字符串 

复制代码 代码如下: 

delimiter = ',' 
mylist = ['brazil', 'russia', 'india', 'china'] 
print delimiter.join(mylist) 

18、php 中 addslashes 的实现 

复制代码 代码如下: 

def addslashes(s): 
    d = {'"':'\"', "'":"\'", "":"\", "\":"\\"} 
    return ''.join(d.get(c, c) for c in s) 

s = "john 'johny' doe (a.k.a. "super joe")\" 
print s 
print addslashes(s) 

19、只显示字母与数字 

复制代码 代码如下: 

def onlycharnum(s,oth=''): 
    s2 = s.lower(); 
    fomart = 'abcdefghijklmnopqrstuvwxyz0123456789' 
    for c in s2: 
        if not c in fomart: 
            s = s.replace(c,''); 
    return s; 

print(onlystr("a000 aa-b")) 


20、截取字符串 

复制代码 代码如下: 

str = '0123456789′ 
print str[0:3] #截取第一位到第三位的字符 
print str[:] #截取字符串的全部字符 
print str[6:] #截取第七个字符到结尾 
print str[:-3] #截取从头开始到倒数第三个字符之前 
print str[2] #截取第三个字符 
print str[-1] #截取倒数第一个字符 
print str[::-1] #创造一个与原字符串顺序相反的字符串 
print str[-3:-1] #截取倒数第三位与倒数第一位之前的字符 
print str[-3:] #截取倒数第三位到结尾 
print str[:-5:-3] #逆序截取,具体啥意思没搞明白? 

21、字符串在输出时的对齐 

复制代码 代码如下: 

s.ljust(width,[fillchar]) 
#输出width个字符,s左对齐,不足部分用fillchar填充,默认的为空格。 
s.rjust(width,[fillchar]) #右对齐 
s.center(width, [fillchar]) #中间对齐 
s.zfill(width) #把s变成width长,并在右对齐,不足部分用0补足 

22、字符串中的搜索和替换 

复制代码 代码如下: 

s.find(substr, [start, [end]]) 
#返回s中出现substr的第一个字母的标号,如果s中没有substr则返回-1。start和end作用就相当于在s[start:end]中搜索 
s.index(substr, [start, [end]]) 
#与find()相同,只是在s中没有substr时,会返回一个运行时错误 
s.rfind(substr, [start, [end]]) 
#返回s中最后出现的substr的第一个字母的标号,如果s中没有substr则返回-1,也就是说从右边算起的第一次出现的substr的首字母标号 
s.rindex(substr, [start, [end]]) 
s.count(substr, [start, [end]]) #计算substr在s中出现的次数 
s.replace(oldstr, newstr, [count]) 
#把s中的oldstar替换为newstr,count为替换次数。这是替换的通用形式,还有一些函数进行特殊字符的替换 
s.strip([chars]) 
#把s中前后chars中有的字符全部去掉,可以理解为把s前后chars替换为none 
s.lstrip([chars]) 
s.rstrip([chars]) 
s.expandtabs([tabsize]) 
#把s中的tab字符替换没空格,每个tab替换为tabsize个空格,默认是8个 

23、字符串的分割和组合 

复制代码 代码如下: 

s.split([sep, [maxsplit]]) 
#以sep为分隔符,把s分成一个list。maxsplit表示分割的次数。默认的分割符为空白字符 
s.rsplit([sep, [maxsplit]]) 
s.splitlines([keepends]) 
#把s按照行分割符分为一个list,keepends是一个bool值,如果为真每行后而会保留行分割符。 
s.join(seq) #把seq代表的序列──字符串序列,用s连接起来 

24、字符串的mapping,这一功能包含两个函数 

复制代码 代码如下: 

string.maketrans(from, to) 
#返回一个256个字符组成的翻译表,其中from中的字符被一一对应地转换成to,所以from和to必须是等长的。 
s.translate(table[,deletechars]) 
# 使用上面的函数产后的翻译表,把s进行翻译,并把deletechars中有的字符删掉。需要注意的是,如果s为unicode字符串,那么就不支持 deletechars参数,可以使用把某个字符翻译为none的方式实现相同的功能。此外还可以使用codecs模块的功能来创建更加功能强大的翻译表。 

25、字符串还有一对编码和解码的函数 

复制代码 代码如下: 

s.encode([encoding,[errors]]) 
# 其中encoding可以有多种值,比如gb2312 gbk gb18030 bz2 zlib big5 bzse64等都支持。errors默认值为"strict",意思是unicodeerror。可能的值还有'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 和所有的通过codecs.register_error注册的值。这一部分内容涉及codecs模块,不是特明白 
s.decode([encoding,[errors]]) 

26、字符串的测试、判断函数,这一类函数在string模块中没有,这些函数返回的都是bool值 

复制代码 代码如下: 

s.startswith(prefix[,start[,end]]) 
#是否以prefix开头 
s.endswith(suffix[,start[,end]]) 
#以suffix结尾 
s.isalnum() 
#是否全是字母和数字,并至少有一个字符 
s.isalpha() #是否全是字母,并至少有一个字符 
s.isdigit() #是否全是数字,并至少有一个字符 
s.isspace() #是否全是空白字符,并至少有一个字符 
s.islower() #s中的字母是否全是小写 
s.isupper() #s中的字母是否便是大写 
s.istitle() #s是否是首字母大写的 

27、字符串类型转换函数,这几个函数只在string模块中有 

复制代码 代码如下: 

string.atoi(s[,base]) 
#base默认为10,如果为0,那么s就可以是012或0x23这种形式的字符串,如果是16那么s就只能是0x23或0x12这种形式的字符串 
string.atol(s[,base]) #转成long 
string.atof(s[,base]) #转成float 


这里再强调一次,字符串对象是不可改变的,也就是说在python创建一个字符串后,你不能把这个字符中的某一部分改变。任何上面的函数改变了字符串后,都会返回一个新的字符串,原字串并没有变。其实这也是有变通的办法的,可以用s=list(s)这个函数把s变为由单个字符为成员的list,这样的话就可以使用s[3]='a'的方式改变值,然后再使用s=" ".join(s)还原成字符串


print s 
print addslashes(s) 

19、只显示字母与数字 

复制代码 代码如下: 

def onlycharnum(s,oth=''): 
    s2 = s.lower(); 
    fomart = 'abcdefghijklmnopqrstuvwxyz0123456789' 
    for c in s2: 
        if not c in fomart: 
            s = s.replace(c,''); 
    return s; 

print(onlystr("a000 aa-b")) 


20、截取字符串 

复制代码 代码如下: 

str = '0123456789′ 
print str[0:3] #截取第一位到第三位的字符 
print str[:] #截取字符串的全部字符 
print str[6:] #截取第七个字符到结尾 
print str[:-3] #截取从头开始到倒数第三个字符之前 
print str[2] #截取第三个字符 
print str[-1] #截取倒数第一个字符 
print str[::-1] #创造一个与原字符串顺序相反的字符串 
print str[-3:-1] #截取倒数第三位与倒数第一位之前的字符 
print str[-3:] #截取倒数第三位到结尾 
print str[:-5:-3] #逆序截取,具体啥意思没搞明白? 

21、字符串在输出时的对齐 

复制代码 代码如下: 

s.ljust(width,[fillchar]) 
#输出width个字符,s左对齐,不足部分用fillchar填充,默认的为空格。 
s.rjust(width,[fillchar]) #右对齐 
s.center(width, [fillchar]) #中间对齐 
s.zfill(width) #把s变成width长,并在右对齐,不足部分用0补足 

22、字符串中的搜索和替换 

复制代码 代码如下: 

s.find(substr, [start, [end]]) 
#返回s中出现substr的第一个字母的标号,如果s中没有substr则返回-1。start和end作用就相当于在s[start:end]中搜索 
s.index(substr, [start, [end]]) 
#与find()相同,只是在s中没有substr时,会返回一个运行时错误 
s.rfind(substr, [start, [end]]) 
#返回s中最后出现的substr的第一个字母的标号,如果s中没有substr则返回-1,也就是说从右边算起的第一次出现的substr的首字母标号 
s.rindex(substr, [start, [end]]) 
s.count(substr, [start, [end]]) #计算substr在s中出现的次数 
s.replace(oldstr, newstr, [count]) 
#把s中的oldstar替换为newstr,count为替换次数。这是替换的通用形式,还有一些函数进行特殊字符的替换 
s.strip([chars]) 
#把s中前后chars中有的字符全部去掉,可以理解为把s前后chars替换为none 
s.lstrip([chars]) 
s.rstrip([chars]) 
s.expandtabs([tabsize]) 
#把s中的tab字符替换没空格,每个tab替换为tabsize个空格,默认是8个 

23、字符串的分割和组合 

复制代码 代码如下: 

s.split([sep, [maxsplit]]) 
#以sep为分隔符,把s分成一个list。maxsplit表示分割的次数。默认的分割符为空白字符 
s.rsplit([sep, [maxsplit]]) 
s.splitlines([keepends]) 
#把s按照行分割符分为一个list,keepends是一个bool值,如果为真每行后而会保留行分割符。 
s.join(seq) #把seq代表的序列──字符串序列,用s连接起来 

24、字符串的mapping,这一功能包含两个函数 

复制代码 代码如下: 

string.maketrans(from, to) 
#返回一个256个字符组成的翻译表,其中from中的字符被一一对应地转换成to,所以from和to必须是等长的。 
s.translate(table[,deletechars]) 
# 使用上面的函数产后的翻译表,把s进行翻译,并把deletechars中有的字符删掉。需要注意的是,如果s为unicode字符串,那么就不支持 deletechars参数,可以使用把某个字符翻译为none的方式实现相同的功能。此外还可以使用codecs模块的功能来创建更加功能强大的翻译表。 

25、字符串还有一对编码和解码的函数 

复制代码 代码如下: 

s.encode([encoding,[errors]]) 
# 其中encoding可以有多种值,比如gb2312 gbk gb18030 bz2 zlib big5 bzse64等都支持。errors默认值为"strict",意思是unicodeerror。可能的值还有'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 和所有的通过codecs.register_error注册的值。这一部分内容涉及codecs模块,不是特明白 
s.decode([encoding,[errors]]) 

26、字符串的测试、判断函数,这一类函数在string模块中没有,这些函数返回的都是bool值 

复制代码 代码如下: 

s.startswith(prefix[,start[,end]]) 
#是否以prefix开头 
s.endswith(suffix[,start[,end]]) 
#以suffix结尾 
s.isalnum() 
#是否全是字母和数字,并至少有一个字符 
s.isalpha() #是否全是字母,并至少有一个字符 
s.isdigit() #是否全是数字,并至少有一个字符 
s.isspace() #是否全是空白字符,并至少有一个字符 
s.islower() #s中的字母是否全是小写 
s.isupper() #s中的字母是否便是大写 
s.istitle() #s是否是首字母大写的 

27、字符串类型转换函数,这几个函数只在string模块中有 

复制代码 代码如下: 

string.atoi(s[,base]) 
#base默认为10,如果为0,那么s就可以是012或0x23这种形式的字符串,如果是16那么s就只能是0x23或0x12这种形式的字符串 
string.atol(s[,base]) #转成long 
string.atof(s[,base]) #转成float 


这里再强调一次,字符串对象是不可改变的,也就是说在python创建一个字符串后,你不能把这个字符中的某一部分改变。任何上面的函数改变了字符串后,都会返回一个新的字符串,原字串并没有变。其实这也是有变通的办法的,可以用s=list(s)这个函数把s变为由单个字符为成员的list,这样的话就可以使用s[3]='a'的方式改变值,然后再使用s=" ".join(s)还原成字符串

索特旅游线路发布管理系统VIP版
索特旅游线路发布管理系统VIP版

一套专门解决旅行社网上预定、发布、管理线路的强大系统,系统基于ASP+ACCESS数据库开发,功能强大,操作方便,系统设计完全符合旅行社的运做模式。系统着重体现易操作性,只要您会打字,便操作。系统由以下几个模块组成:1、线路的类别发布和管理2、线路的发布和管理3、线路的属性管理(是精品线路、还是普通线路)4、客户预定线路订单管理,人性化的区分为未处理订但和处理订单5、线路查询功能6、网站留言功能,

下载

相关文章

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

2

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

80

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

187

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

339

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

116

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

180

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

31

2026.03.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

81

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 10.1万人学习

Web前端入门基础教程
Web前端入门基础教程

共251课时 | 40.7万人学习

一周时间让你轻松掌握Linux
一周时间让你轻松掌握Linux

共153课时 | 25.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号