python dict的get使用默认键值

python的dict的get使用默认键值

1.以一个例子说开

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

如上,既然都以0x为开头,则可以把头两位切片去掉
比如,0x1a12 ,切片去掉头两位是 1a12
转为十进制是 116^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分别进行处理(在测试不同的方法时间性能的时候,似乎第一种时间更少一些)

转载于:https://www.cnblogs.com/haozike/p/python_dict_get.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值