如果另一个列表的某个条件为真,则覆盖列表值 (python)
Overwrite a list value if a certain condition for another list is true (python)
不幸的是,我无法更具体地说明我的标题,但一个例子应该可以清楚地说明我的问题。我有两个列表 f 和 a,如果 f[i] 等于 f[i-1]。我想在 f 中有一个等于 f[i] 和 f[i-1] 的新条目(显然)并覆盖它们。在 a 我想必须 a_new = a[i] + a[i-1] 替换 a[i] 和 a[i-1].
f = [10, 25, 50, 50, 75, 100, 1000, 1000, 1100, 1100]
a = [1, 3, 2, 4, 5, 3, 10, 15, 5, 5]
我想要的输出是:
f = [10, 25, 50, 75, 100, 1000, 1100]
a = [1, 3, 6, 5, 3, 25, 10]
我相信某种列表理解是最佳方法,但我还想不出来。虽然我不需要列表理解,但只要有一些解决方案我就很高兴。
您可以将列表 zip
放在一起,使用 groupby
按 f
值对这些对进行分组,然后对每个组的 a
值求和。然后你只需要将它们解压缩回单独的列表
from itertools import groupby
from operator import itemgetter
groups = groupby(zip(f, a), key=itemgetter(0))
f_a_generator = ((k, sum(map(itemgetter(1), pairs))) for k, pairs in groups)
f1, a1 = zip(*f_a_generator) # map(list, ...) If you need them as lists
print(f1, a1, sep='\n')
# (10, 25, 50, 75, 100, 1000, 1100)
# (1, 3, 6, 5, 3, 25, 10)
要在评论中回答您的问题,您可以更改行
sum(map(itemgetter(1), pairs)))
调用sum
以外的函数:
def logarithmic_sum(values):
return 10*np.log10(sum((10**(val/10)) for val in values))
groups = groupby(zip(f, a), key=itemgetter(0))
f_a_generator = ((k, logarithmic_sum(map(itemgetter(1), pairs))) for k, pairs in groups)
f1, a1 = zip(*f_a_generator)
print(f1, a1, sep='\n')
# (10, 25, 50, 75, 100, 1000, 1100)
# (1.0000000000000002, 2.999999999999999, 6.124426027943397, 5.0, 2.999999999999999, 16.193310480660944, 8.010299956639813)
对于第一个数组情况:
for i in range(1, len(f)-2):
if f[i] == f[i-1]:
del f[i]
print(f)
不幸的是,我无法更具体地说明我的标题,但一个例子应该可以清楚地说明我的问题。我有两个列表 f 和 a,如果 f[i] 等于 f[i-1]。我想在 f 中有一个等于 f[i] 和 f[i-1] 的新条目(显然)并覆盖它们。在 a 我想必须 a_new = a[i] + a[i-1] 替换 a[i] 和 a[i-1].
f = [10, 25, 50, 50, 75, 100, 1000, 1000, 1100, 1100]
a = [1, 3, 2, 4, 5, 3, 10, 15, 5, 5]
我想要的输出是:
f = [10, 25, 50, 75, 100, 1000, 1100]
a = [1, 3, 6, 5, 3, 25, 10]
我相信某种列表理解是最佳方法,但我还想不出来。虽然我不需要列表理解,但只要有一些解决方案我就很高兴。
您可以将列表 zip
放在一起,使用 groupby
按 f
值对这些对进行分组,然后对每个组的 a
值求和。然后你只需要将它们解压缩回单独的列表
from itertools import groupby
from operator import itemgetter
groups = groupby(zip(f, a), key=itemgetter(0))
f_a_generator = ((k, sum(map(itemgetter(1), pairs))) for k, pairs in groups)
f1, a1 = zip(*f_a_generator) # map(list, ...) If you need them as lists
print(f1, a1, sep='\n')
# (10, 25, 50, 75, 100, 1000, 1100)
# (1, 3, 6, 5, 3, 25, 10)
要在评论中回答您的问题,您可以更改行
sum(map(itemgetter(1), pairs)))
调用sum
以外的函数:
def logarithmic_sum(values):
return 10*np.log10(sum((10**(val/10)) for val in values))
groups = groupby(zip(f, a), key=itemgetter(0))
f_a_generator = ((k, logarithmic_sum(map(itemgetter(1), pairs))) for k, pairs in groups)
f1, a1 = zip(*f_a_generator)
print(f1, a1, sep='\n')
# (10, 25, 50, 75, 100, 1000, 1100)
# (1.0000000000000002, 2.999999999999999, 6.124426027943397, 5.0, 2.999999999999999, 16.193310480660944, 8.010299956639813)
对于第一个数组情况:
for i in range(1, len(f)-2):
if f[i] == f[i-1]:
del f[i]
print(f)