>>>aa="hi" >>>num=[0,1,2,3,4,5] >>>for i in num : if i >0: print(aa) hi hi hi hi hi
上面这个就是实现“把某个字符串,反复出现某list里满足条件的元素次数”,这个得到的结果是一个str,如果要简化一下这段代码如下:
>>>[aa for i in num if i >0] [hi,hi,hi,hi,hi]
这里一定要有中括号,不然的话算SyntaxError: invalid syntax。得到的结果是一个list。
rm.sub模块
sub模块主要是字符串的针对性替换作用,使用格式是text.sub(r"要替换的内容","替换成的内容",替换范围),举个例子:
>>>import re >>>s0="james and wade" >>>s1=re.sub(r"james","bosh",s0) #r指的是原生字符串的意思 >>>print(s1) bosh and girl
sub模块支持 | 的引用,比如把上面代码修改一下:
>>>import re >>>s0="james and wade" >>>s2=re.sub(r"james|wade","bosh",s0) # | 就是或的意思 >>>print(s2) bosh and bosh
但是要注意,如果类似于linux里的或,用[]括起来的话,结果可大不相同:
>>>import re >>>s0="james and wade" >>>s3=re.sub(r"[james|kobe]","bosh",s0) # 这里原来打算把james或者kobe替换成bosh >>>print(s3) boshboshboshboshbosh boshnd wboshdbosh #可以看出只要是 j a m e s k o b e这几个字母就都变成了bosh,而出现了boshnd,是应为n和d 不属于上面几个字母,所以nd保留了下来。
如果要把每一项都改,可以用[a-z],
>>>import re >>>s0="james and wade" >>>s4=re.sub(r"[a-z]","bosh",s0) >>>print(s4) boshboshboshboshbosh boshboshbosh boshboshboshbosh
那么对于数字而言,就是[1-9],但是有没有一种方式,把所有的元素都包括了呢?有的,那就是\w
>>>import re >>>s0="james23 and wade3" #这是一个混杂型的字符串,里面有数字、字母 >>>s5=re.sub(r"\w","bosh",s0) >>>print(s5) boshboshboshboshbosh boshboshbosh boshboshboshbosh
\w对于“@#¥%^$”特殊符号是不好使的。
re还有一个subn的模块,再看看这个。
>>> import re >>> s="1abc23def45" >>> print(str(re.subn(r"\w","hi",s)[1])) 11 #这个是体现了一共替换了多少次, >>> print(str(re.subn(r"\w","hi",s)[0])) hihihihihihihihihihihi #只有[0]和[1] >>> print(str(re.subn(r"\w","hi",s))) (‘hihihihihihihihihihihi‘, 11) >>> print(str(re.subn(r"[a-z]","hi",s))) (‘1hihihi23hihihi45‘, 6)
时间: 2024-11-29 06:18:17