|
|
发表于 2019-1-10 11:55:06
|
显示全部楼层
本楼为最佳答案
你对疑问在这一句程序,print('十进制 -> 十六进制 : %d -> 0x%x' % (num, num))
这一句中有字符的格式化输出,你可能对格式化输出不太理解,这是格式化输出的一种方式,即在引号''中的字符串中插入需要进行转化的格式(如%d,%s,%x,%o等),然后在引号外用%列出许进行格式转化的元素列表,这句程序中引号''中有一个%d和一个%x,所以在引号外就需要给出两个元素的列表即%(num,num)其中第一个num是以十进制(%d)格式输出,第二个num是以十六进制(%x)格式输出。而引号''中%x迁的0x是正常的字符串内容,只是为了在输出结果中标明这个是十六进制而已。
下一行print与这一行一样。再下一行print中和这一行略有不同,是因为用%进行格式化输出,没有二进制格式,因此只能先输出前面部分'十进制 -> 二进制 : %d -> ',这里面只有一个格式转化%d,所以后面只有一个%num,在向后就是逗号‘,’了逗号后面是其他输出内容。
其实还有其他格式化输出方式,可能会让你更好的理解。就是用“.format”表示,例如上面那一句可以写成 print('十进制 -> 十六进制 : {0:d} -> 0x{1:x}' .format(num, num)) 在输出字符串引号''中写上形参{0} {1},然后在后面以“.format”引出实参,这样则会一一对应。形参中的冒号后面是格式化的形式,如 {0:d} 中的d是十进制,{1:x}中的x是十六进制。这句话的输出和你的那种写法输出完全一样,但是更方便你理解。 |
评分
-
查看全部评分
|