大家早好、午好、晚好吖 ❤ ~欢迎光临本文章
话不多说,直接开搞,如果有什么疑惑/资料需要的可以点击文章末尾名片领取源码
在使用正则替换时,有时候需要将匹配的结果做对应处理,便可以使用自定义替换方法。
re.sub的用法为:
re.sub('匹配表达式',替换字符或替换函数,替换次数,其他参数)
例如,加入将字符串中的$开头的变量替换为上下文context中对应的值,可以操作如下。
import re
context = {'a': 1, 'b': 2, 'except': 3}
text = '$a + $b = $except'
def repl_func(matched):
if matched:
text = matched.group(1)
return str(context.get(text))
result = re.sub('\$(\w+)', repl_func, text)
print(result)
打印结果为:
1 + 2 = 3
下面是一个用于替换字符串,字典,列表,元祖类型中特定变量的方法。
'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:702813599
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import re
import json
def parser(origin, *args, delimiter="$", **kwargs): # 支持修改delimiter定界符
patten = r'\{}(?P<var>.+?)'.format(delimiter)
def repl_func(matched): # 自定义re.sub使用的替换方法
var = matched.group('var')
if var.isdigit(): # 如果是数字, 则从args中替换
index = int(var) - 1
if index < len(args):
return args[index]
else:
return "{}{}".format(delimiter, var) # 无替换参数则返回原值
else:
return kwargs.get(var, None) or "{}{}".format(delimiter, var) # 返回kwargs参数中值 or 原值
if isinstance(origin, str):
return re.sub(patten, repl_func, origin, re.M)
elif isinstance(origin, (dict, list)): # 使用json.dumps转为字符串, 替换,然后重新转为dict/list
return json.loads(re.sub(patten, repl_func, json.dumps(origin), re.M))
else:
if isinstance(origin, tuple):
return tuple(json.loads(re.sub(patten, repl_func, json.dumps(origin), re.M))) # 转换后重新转为tuple
if __name__ == '__main__':
s = ['性别: $2 年龄: $3\n$a', '$1', {"say": "$a"}]
print(parser(s, 'kevin', 'male', '20', a="hello, world!"))
好了,今天的分享就差不多到这里了!
对下一篇大家想看什么,可在评论区留言哦!看到我会更新哒(ง •_•)ง
喜欢就关注一下博主,或点赞收藏评论一下我的文章叭!!!