当我们在做字符串处理时,如果字符串处理函数不能实现我们想要的时,我们就借助正则来帮助我们实现了。
#1 匹配Math(并获取出结果)(注意这里是要获取出匹配结果的,与不获取结果有所不同)<wbr style="padding:0px; margin:0px"></wbr>
PHP:
<?php$strs='我爱P你y你t知h吗o?n哈哈fe哈';preg_match('/^.*?(\w+).*?$/i',$strs,$m);var_dump($m[1]);
#输出:string'P'(length=1)
preg_match('/(\w+)/',$strs,$m);
patt=re.compile(r'(\w+)',re.I)printpatt.search(strs).group(1)#输出 P
patt=re.compile(r'\w+',re.I)foriinpatt.split(strs):#注意这里要使用unicode对象输出printunicode(i,'utf-8')#以上输出'''我爱你你知吗?哈哈哈'''
在PHP中可以使用preg_split()来实现<?php$strs='我爱P你y你t知h吗o?n哈哈fe哈';$m=preg_split('/\w+/i',$strs);var_dump($m);
/**输出:
array 0 => string '我爱' (length=6) 1 => string '你' (length=3) 2 => string '你' (length=3) 3 => string '知' (length=3) 4 => string '吗' (length=3) 5 => string '?' (length=3) 6 => string '哈哈' (length=6) 7 => string '哈' (length=3)
printpatt.findall(strs)#输出 ['P', 'y', 't', 'h', 'o', 'n', 'fe']
<?php$strs='我爱P你y你t知h吗o?n哈哈fe哈';preg_match_all('/(\w+)/i',$strs,$m);var_dump($m);
/**
array 0 => array 0 => string 'P' (length=1) 1 => string 'y' (length=1) 2 => string 't' (length=1) 3 => string 'h' (length=1) 4 => string 'o' (length=1) 5 => string 'n' (length=1) 6 => string 'fe' (length=2) 1 => array 0 => string 'P' (length=1) 1 => string 'y' (length=1) 2 => string 't' (length=1) 3 => string 'h' (length=1) 4 => string 'o' (length=1) 5 => string 'n' (length=1) 6 => string 'fe' (length=2) **/
foriinpatt.finditer(strs):printi.group()#以上输出'''Pythonfe'''
这和PHP中的preg_filter()有所不同,preg_filter()与preg_replace()都是执行一个正则表达式的搜索和替换。在python中正则方法中,用于查找替换的是:sub()与subn()。#这里批量替换文章中的图片的路径(old_c 是文章的内容)
img_dir = 'test'
img_patt = re.compile('src=".*?/(\w+\.\w+)"')
new_c = img_patt.sub(r'src="./%s/\1"'%img_dir,old_c) PHP:
#这里批量替换文章中的图片的路径(old_c 是文章的内容)
img_dir = 'test'img_patt=re.compile('src=".*?/(\w+\.\w+)"')new_c=img_patt.sub(r'src="./%s/\1"'%img_dir,old_c) #输出:
string '我爱999你999你999知999吗999?999哈哈999哈' (length=51)