import re
def reg_exp(senten):
jiqiren = "阿童木"
matchObj1 = re.search( r'(你(.*?)(男|女))|(机器(.*?)(男|女))|((.*?)(男的|男|女的|女))|(.*?)(什么(.*?)(性别))', senten, re.M|re.I)
matchObj2 = re.search( r''+ str(jiqiren) + '(.*?)(名字|姓名|叫什么|叫什么名|叫什么名字)', senten, re.M|re.I)
if matchObj1:
print ("我是男的啊")
elif matchObj2:
print ("我叫阿童木")
else:
print ("No match!!")
if __name__=="__main__":
senten = "阿童木的名字"
reg_exp(senten)
注意
'+ str(jiqiren) + ' 要和r' 靠紧写。 这也验证了,正则表达式也可以写在txt里面,然后一行行读出来和r'配合。我们一起来见证下。之前搞了好久,这次灵感来了,分分钟解决
1 importre2
3 defreg_exp(senten):4 f = open("reg.txt")5 lines = f.readlines()#读取全部内容
6 for line inlines:7 print(line)8
9 matchObj1 = re.search( r''+ line +'', senten, re.M|re.I)10 ifmatchObj1:11 print ("我是男的啊")12 else:13 print ("No match!!")14
15
16 if __name__=="__main__":17 senten = "你是男"
18 reg_exp(senten)
其中reg.txt的内容是 (你(.*?)(男|女))|(机器(.*?)(男|女))|((.*?)(男的|男|女的|女))|(.*?)(什么(.*?)(性别)) 运行结果如下:
参考文章:
https://www.cnblogs.com/yangshuo/archive/2013/06/06/3120595.html