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分别进行处理(在测试不同的方法时间性能的时候,似乎第一种时间更少一些)