使用re正则表达式验证罗马数字中的百位

代码:

# 验证罗马数字中的百位
pattern2 = '^M?M?M?(CM|CD|D?C?C?C?)$'
print(re.search(pattern2,  'MCM'))
print(re.search(pattern2, 'MD'))
print(re.search(pattern2, 'MMMCCC'))
print(re.search(pattern2, 'MCMC'))
print(re.search(pattern2, ''))

解析:

  • ^表示必须从字符串开头匹配。
  • ?表示匹配是可选的
  • (  |   |   )表示三种模式选择一个
  • re.search(参数一,参数二) 参数一为正则表达式,参数二为要验证的字符串。

表达式:'^M?M?M?(CM|CD|D?C?C?C?)$' 首先必须以M开头,括号内表示可选。

  • re.search(pattern2,  'MCM')
  1. 首先匹配M,
  2. 后面两个M没有匹配所以忽略,
  3. 继续匹配括号内的三选一,
  4. 匹配到CM,
  5. 结束

后面几个例子照推即可。

猜你喜欢

转载自blog.csdn.net/zphuangtang/article/details/109095915