使用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')
- 首先匹配M,
- 后面两个M没有匹配所以忽略,
- 继续匹配括号内的三选一,
- 匹配到CM,
- 结束
后面几个例子照推即可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~