【请教】关于二进制转换十进制编写函数的一个问题
最近看了一篇python十进制和二进制的转换方法(含浮点数)中,二进制转换十进制程序如下:# 把一个带小数的二进制数n转换成十进制
# 小数点后面保留pre位小数
from decimal import Decimal
def binTodec(n, pre=4):
'''
把一个带小数的二进制数n转换成十进制
小数点后面保留pre位小数
'''
string_number1 = str(n)# number1 表示二进制数,number2表示十进制数
decimal = 0# 小数部分化成二进制后的值
flag = False
for i in string_number1:# 判断是否含小数部分
if i == '.':
flag = True
break
if flag:# 若二进制数含有小数部分
string_integer, string_decimal = string_number1.split('.')# 分离整数部分和小数部分
for i in range(len(string_decimal)):
decimal += 2 ** (-i - 1) * int(string_decimal)# 小数部分化成二进制
number2 = int(str(int(string_integer, 2))) + decimal
return round(number2, pre)
else:# 若二进制数只有整数部分
return int(string_number1, 2)# 若只有整数部分 直接一行代码二进制转十进制
其中有一条语句是
number2 = int(str(int(string_integer, 2))) + decimal
我不太理解 int(str(int(string_integer, 2)))为什么不直接写成int(string_integer, 2)?
number2 = int(string_integer, 2) + decimal
是有什么技巧在这里面吗?
没什么技巧,就是他写错了吧
页:
[1]