web-dev-qa-db-ja.com

文字列がパターンと一致するか確認する

文字列がこのパターンに一致するかどうかをどうやって確認するのですか?

大文字、数字、大文字、数字...

例、これらは一致します。

A1B2
B10L1
C1N200J1

そうではありません( '^'は問題を示しています)

a1B2
^
A10B
   ^
AB400
^
222
DanielTA
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

350
CrazyCasta

ワンライナー: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
127
nehemiah

以下を試してください。

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())
32
sumeet agrawal
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'
22
Marc Cohen

正規表現はこれを簡単にします...

[A-Z]は、AとZの間の正確に1文字に一致します

\d+は1桁以上の数字に一致します

()で物事をグループ化します(そしてまた物事を返します...しかし今のところはそれらをグループ化することだけを考えてください)

+は1つ以上を選択します

7
Joran Beasley

import re

ab = re.compile("^([A-Z]{1}[0-9]{1})+$")
ab.match(string)
  


大文字、number パターンでうまくいくはずです。

6