本文實例講述了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
函數使用方法:
getRomanNum('MDCCCLXXXVIII')
就會獲得1888
Python代碼:
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'
PS:這里再為大家提供一款換算工具供大家參考使用:
在線萬能單位換算器flash版:
http://tools.jb51.net/zhuanhuanqi/all_zhuanhuanqi
新聞熱點
疑難解答