本文共 2434 字,大约阅读时间需要 8 分钟。
罗马数字,我们在某些电视中或者现实生活中都曾经看到过,近日,学习Python时,也遇到了罗马数字的解说,于是顺便写了一个小程序来练习罗马数字到我们日常生活普通数字之间的转换的小函数。
首先,咱们了解一下,罗马数字的潜在法则, 在罗马数字中,利用7个不同字母进行重复或者组合来表达各式各样的数字。 I = 1V = 5X = 10L = 50C = 100D = 500M = 1000其组合关系是: 上面的字符最多能同时连续的使用三次 比如:4,罗马数字就应该是IV,而不是IIII,超过三个组合时,就要使用低高组合,4就是I和V的组合,I表示1,V表示5函数使用方法: getRomanNum('MDCCCLXXXVIII')就会获得1888
PythonCode:
def getRomanNum(RomanStr): """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://pesti.baihongyu.com/