python dict的get使用默认键值

python的dict的get使用默认键值

1.以一个例子说开

十六进制转为十进制
输入任意长度的十六进制数,转为十进制数,该十六进制一定以0x为开头

如上,既然都以0x为开头,则可以把头两位切片去掉
比如,0x1a12 ,切片去掉头两位是 1a12
转为十进制是 1*16^3 + 10 * 16^2 + 1 * 16^1 + 2 * 16^0
我们可以把切片去掉头两位后得到的字符串逆序,得到 21a1,这样循环处理,随着位数的上升,其对应的16N次方的N也不断上升,这样处理比较自然

import math
while True:
    hexdict = {'A':10,'B':11,'C':12,'D':13,'E':14,'F':15}
    try:
        rawdata = raw_input()[2:]
        sum = 0
        if rawdata:
            hexdata = rawdata.upper()[::-1]
            length = len(hexdata)
            for i in xrange(length):
                if hexdata[i] >= '0' and hexdata[i] <= '9':
                    sum = sum + int(hexdata[i]) * math.pow(16,i)
                elif hexdata[i] >= 'A' and hexdata[i] <= 'F':
                    sum = sum + int(hexdict.get(hexdata[i])) * math.pow(16,i)
            print(int(sum))
    except:
        break

可以看到,针对十六进制数中可能出现0-9和A-F分别进行了处理。
可以不可以少些几行代码,用统一的方式处理0-9和A-F呢?

这就需要字典的get方法使用默认键值

import math
while True:
    hexdict = {'A':10,'B':11,'C':12,'D':13,'E':14,'F':15}
    try:
        rawdata = raw_input()[2:]
        sum = 0
        if rawdata:
            hexdata = rawdata.upper()[::-1]
            length = len(hexdata)
            for i in xrange(length):
                sum = sum+int(hexdict.get(hexdata[i],hexdata[i]))*math.pow(16,i)
            print(int(sum))
        else:
            break
    except:
        break

字典的get方法可以给字典设置默认键值,当指定的键获取不到键值时,就使用参数指定的默认键值。
在这里,当hexdata[i]在hexdict中有键值对应的时候,即这个数是A-F的时候,就可以取到A-F进行计算
当hexdata[i]在hexdict中没有键值对应的时候,即这个数是0-9的时候,就是用0-9自身作为键值,进行计算
这样,就不需要针对0-9和A-F分别进行处理(在测试不同的方法时间性能的时候,似乎第一种时间更少一些)

posted @ 2018-08-18 16:37  aaa1111sss  阅读(1161)  评论(0编辑  收藏  举报