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 import re 2 3 def reg_exp(senten): 4 f = open("reg.txt") 5 lines = f.readlines()#读取全部内容 6 for line in lines: 7 print (line) 8 9 matchObj1 = re.search( r‘‘+ line +‘‘, senten, re.M|re.I) 10 if matchObj1: 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