Как проверить, соответствует ли строка этому шаблону?
Верхняя буква, число (число), прописная буква, число (ы)...
Пример: они будут соответствовать:
A1B2
B10L1
C1N200J1
Это не будет ('^' указывает на проблему)
a1B2
^
A10B
^
AB400
^
import re
pattern = re.compile("^([A-Z][0-9]+)+$")
pattern.match(string)
One-liner: 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
в первой строке
re.match
в контексте if
, но вы должны использовать bool
если вы используете его в другом месте?
Попробуйте следующее:
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
\d+
будет соответствовать одной или нескольким цифрам
()
группировать вещи (а также возвращать вещи... но на данный момент просто подумайте об их группировке)
+
выбирает 1 или более
import re
ab = re.compile("^([A-Z]{1}[0-9]{1})+$")
ab.match(string)
Я считаю, что это должно работать для шаблона верхнего, число.
{1}
поскольку он уже подразумевается.
^([AZ]\d+){1,}$
как это?