なぜこれが機能しないのかわかりません:
import re
import csv
def check(q, s):
match = re.search(r'%s' % q, s, re.IGNORECASE)
if match:
return True
else:
return False
tstr = []
# test strings
tstr.append('testthisisnotworking')
tstr.append('This is a TEsT')
tstr.append('This is a TEST mon!')
f = open('testwords.txt', 'rU')
reader = csv.reader(f)
for type, term, exp in reader:
for i in range(2):
if check(exp, tstr[i]):
print exp + " hit on " + tstr[i]
else:
print exp + " did NOT hit on " + tstr[i]
f.close()
testwords.txtには次の行が含まれています。
blah, blah, test
したがって、本質的に「テスト」は正規表現パターンです。複雑なことは何もありません。簡単な言葉です。出力は次のとおりです。
test did NOT hit on testthisisnotworking
test hit on This is a TEsT
test hit on This is a TEST mon!
なぜ最初の文字列にヒットしないのですか?私も\s*test\s*
運が悪かった。ヘルプ?