使用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. 结束

后面几个例子照推即可。

 

posted @   zpcode  阅读(34)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示