故事如下。用户输入一个数字。Python将字符串转换为int,并使用算法生成二进制数。例如:
firstdecimal=input("Please enter your first denary number: ")
> 45
StrToInt = int(firstdecimal)
InputInt = ToBin(StrToInt) # a working binary conversion function
print(InputInt)
> [1, 0, 1, 1, 0, 1]
我需要的是函数Addzero(x)
能够取二进制数列表(InputInt
),并将0
s添加到开头。如果列表中已经有8
元素,则不需要添加0
。
def Addzero(value):
reverse = value[::-1]
if len(value) != 8:
value.extend([0])
if len(value) == 8:
reverse = value[::-1]
elif len(value) == 8:
return
我找不到可以在开头添加元素的代码,所以我只实现了一个反向功能来绕过它
当我打印这个函数的内容时,我得到。。。
> None
这显然不是预期的结果。我需要输出。(由0
、1
组成的完整8
元素列表)
像这样:
> [0, 0, 1, 0, 1, 1, 0, 1]
它返回None
的原因只是因为return
语句缺少一个表达式:
elif len(value) == 8:
return
因此,return
的意思只是:"我们完成了,停止执行此函数,不应返回任何东西"。
此外,并不是所有的代码路径都会执行返回语句。最后,您的AddZero
似乎只添加了一个单个零,这可能是低效的。
更好的解决方案可能是:
def Addzero(value):
return [0] * max(0,8-len(value)) + value
这里表达式[0]*n
表示在列表中重复0
n次。因此CCD_ 15将产生CCD_ 16。现在我们需要添加的次数是max(0,8-len(value))
。事实上,max(0,...)
甚至没有必要,所以您可以将其重写为:
def Addzero(value):
return [0] * (8-len(value)) + value
因此,这意味着我们必须缩短以生成八项列表的元素数量,这些元素被构造为零的列表。我们用+
添加(附加)原始列表。
正如@Later42在他的回答中所示,你可以通过首先进行len
检查来提高效率,如果它等于8,则返回列表本身:
def Addzero(value):
if(len(value) > 8) :
return value
else :
return [0] * (8-len(value)) + value
演示使用Python的交互式shell:
$ python
Python 2.7.9 (default, Apr 2 2015, 15:33:21)
[GCC 4.9.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> def Addzero(value):
... return [0] * (8-len(value)) + value
...
>>> Addzero([1, 0, 1, 1, 0, 1])
[0, 0, 1, 0, 1, 1, 0, 1]
这可能有效吗?我自己没有测试过,但我认为应该没问题。
def add_zero(binary_list):
if len(binary_list) < 8:
zeros = [0] * (8 - len(binary_list))
return zeros + binary_list
else:
return binary_list
我想其他解决方案也很合适,但为什么不直接使用:
firstdecimal = input("Please enter your first denary number: ")
> 45
binaryStr = '{0:08b}'.format(firstdecimal) # string, not a list
print(binaryStr)
> '00101101'
print(list(map(int, binaryStr)) # gives you the list
> [0, 0, 1, 0, 1, 1, 0, 1]
注意,格式字符串中的08b
表示参数firstdecimal
将被转换为零填充的8长度二进制字符串。