马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
最近看了一篇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[i]) # 小数部分化成二进制
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
是有什么技巧在这里面吗?
|