文字列がこのパターンに一致するかどうかをどうやって確認するのですか?
大文字、数字、大文字、数字...
例、これらは一致します。
A1B2
B10L1
C1N200J1
そうではありません( '^'は問題を示しています)
a1B2
^
A10B
^
AB400
^
import re
pattern = re.compile("^([A-Z][0-9]+)+$")
pattern.match(string)
編集:コメントに記載されているように、match
は文字列の先頭の一致のみをチェックしますが、re.search()
は文字列内のどこかのパターンに一致します。 (参照: https://docs.python.org/library/re.html#search-vs-match )
ワンライナー:re.match(r"pattern", string) # No need to compile
import re
>>> if re.match(r"hello[0-9]+", 'hello1'):
... print('Yes')
...
Yes
必要に応じてbool
として評価できます
>>> bool(re.match(r"hello[0-9]+", 'hello1'))
True
以下を試してください。
import re
name = ["A1B1", "djdd", "B2C4", "C2H2", "jdoi","1A4V"]
# Match names.
for element in name:
m = re.match("(^[A-Z]\d[A-Z]\d)", element)
if m:
print(m.groups())
import re
import sys
prog = re.compile('([A-Z]\d+)+')
while True:
line = sys.stdin.readline()
if not line: break
if prog.match(line):
print 'matched'
else:
print 'not matched'
正規表現はこれを簡単にします...
[A-Z]
は、AとZの間の正確に1文字に一致します
\d+
は1桁以上の数字に一致します
()
で物事をグループ化します(そしてまた物事を返します...しかし今のところはそれらをグループ化することだけを考えてください)
+
は1つ以上を選択します
import re
ab = re.compile("^([A-Z]{1}[0-9]{1})+$")
ab.match(string)
大文字、number パターンでうまくいくはずです。