我的一个函数生成一个结果作为可变长度列表,如[1,2,3,...]等。当这些列表出来时,我想将它们全部添加到一些主列表中时尚:
out: [1, 2]
out: [3]
sum:[4,2]
out: [0, 0, 0, 2]
sum: [4, 2, 0, 2]
out: [3, 1]
sum: [7, 3, 0, 2]
等等。
我还需要能够对这些进行操作 - 例如:
[1, 2, 3, 4]/N = [1/N, 2/N, ...]
numpy数组是我想要的格式吗?我似乎无法让它发挥作用。
答案 0 :(得分:2)
您可以使用python 2.x中的map / itertools.izip_longest或python 3.x中的itertools.zip_longest完成功能
说完了,
each
子列表,您可以使用python的sum()内置函数。None
变量中是否存在each
。如果存在,则遍历该子列表,检查每个元素i
是否为None,如果是,则将其替换为0. 即,
>>> addFn = lambda a,b: [sum(each) if None not in each else sum(i if i else 0 for i in each )for each in map(None,a,b)]
>>> addFn([1,2,3],[4])
[5, 2, 3]
>>> addFn(addFn([1,2,3],[4]),[7,3,0,2])
[12, 5, 3, 2]
对于第二个功能,如果你的列表是l
,那么
对于l中的每个元素i
,转换分子或分母浮点数并执行操作!
>>> divByN = lambda l,N:[i/float(N) for i in l]
>>> divByN([5,6,7,8],2)
[2.5, 3.0, 3.5, 4.0]
如Baldrickk所述,这是一个使用itertools的例子,
from itertools import izip_longest as izip_l
sum = [a+b for a,b in izip_l(arr1,arr2, fillvalue=0)]
答案 1 :(得分:0)
import numpy as np
def Add(a, b):
a, b = map(np.array, (a, b))
if a.size > b.size:
a[:b.size] += b
return a
else:
b[:a.size] += a
return b
使用示例:
>>> Add([1,2], [3])
array([ 4., 2.])
>>> Add([0,0,0,2], _)
array([ 4., 2., 0., 2.])
该函数的第一行是获取转换为浮点的这些数组的副本,因此您可以在不进行舍入的情况下进行除法。
答案 2 :(得分:0)
另一种解决方案:
def add_shortest(a, b):
a = numpy.array(a)
b = numpy.array(b)
common_length = min(a.size, b.size)
a[:common_length] += b[:common_length]
return a
add_shortest(numpy.arange(2), numpy.arange(3)) # array([0, 2])
add_shortest(numpy.arange(3), numpy.arange(3)) # array([0, 2, 4])
add_shortest(numpy.arange(3), numpy.arange(2)) # array([0, 2, 2])
add_shortest(add_shortest([0, 0, 0, 2], add_shortest([1, 2], [3])), [3, 1]) # array([7, 3, 0, 2])