玩蛇网提供最新Python编程技术信息以及Python资源下载!
您现在的位置: 玩蛇网首页 > Python源码实例_Python程序源代码_网站项目下载 > 正文内容

用Python罗马数字转换为阿拉伯数字的方法

Python入门佳作 经典教程的全新修订 10个项目引人入胜
玩蛇网推荐图文教程:python黑客多线程扫描器

玩蛇网这篇文章给大家介绍一下用Python罗马数字转换为阿拉伯数字的方法,分享给朋友们,介绍与代码在下面。

大家来了解一下,罗马数字的潜在法则, 在罗马数字中,利用7个不同字母进行重复或者组合来表达各式各样的数字。 

I = 1
V = 5
X = 10
L = 50
C = 100
D = 500
M = 1000
它的组合关系是, 上面的字符最多能同时连续的使用三次

 比如:4,罗马数字就应该是IV,而不是IIII,超过三个组合时,就要使用低高组合,4就是I和V的组合,I表示1,V表示5

用Python罗马数字转换为阿拉伯数字函数使用方法:
  getRomanNum('MDCCCLXXXVIII')就会获得1888

def getRomanNum(RomanStr):
    # 玩蛇网 www.iplaypython.com
 """Roman numerals will be converted into digital,RomanStr is a RomanString"""
     import re
     if re.search('^M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$',RomanStr)!=None:
         NumDic = {"pattern":"","retNum":0}
         RomanPattern = {
             "0":('','','','M'),
             "1":('CM','CD','D','C',100),
             "2":('XC','XL','L','X',10),
             "3":('IX','IV','V','I',1)
             }    
         i = 3
         NumItems = sorted(RomanPattern.items())
         for RomanItem in NumItems:
             if RomanItem[0] != '0':
                 patstr = NumDic["pattern"].join(['',RomanItem[1][0]])
                 if re.search(patstr,RomanStr) != None:
                     NumDic["retNum"] += 9*RomanItem[1][4]
                     NumDic["pattern"] = patstr
                 else:
                     patstr = NumDic["pattern"].join(['',RomanItem[1][1]])
                     if re.search(patstr,RomanStr) != None:
                         NumDic["retNum"] += 4*RomanItem[1][4]
                         NumDic["pattern"] = patstr
                     else:
                         patstr = NumDic["pattern"].join(['',RomanItem[1][2]])
                         if re.search(patstr,RomanStr) != None:
                             NumDic["retNum"] += 5*RomanItem[1][4]
                             NumDic["pattern"] = patstr
             if NumDic["pattern"] == '':
                 NumDic["pattern"] = '^'
             tempstr = ''
             sum = 0
             for k in range(0,4):
                 pstr = RomanItem[1][3].join(['','{']).join(['',str(k)]).join(['','}'])
                 patstr = NumDic["pattern"].join(['',pstr])
                 if re.search(patstr,RomanStr) != None:
                     sum = k*(10**i)
                     tempstr = patstr
             if tempstr <> '':
                 NumDic["pattern"] = tempstr
             else:
                 NumDic["pattern"] = patstr
             NumDic['retNum'] += sum
             i -= 1
         return NumDic['retNum']
     else:
         print 'String is not a valid Roman numerals'

玩蛇网文章,转载请注明出处和来源网址:http://www.iplaypython.com/code/c2721.html



微信公众号搜索"玩蛇网Python之家"加关注,每日最新的Python资讯、图文视频教程可以让你一手全掌握。强烈推荐关注!

微信扫描下图可直接关注

玩蛇网PythonQQ群,欢迎加入: ① 240764603 玩蛇网Python新手群
出炉日期:2015-12-18 12:36 玩蛇网 www.iplaypython.com

我要分享到:
评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules