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