私は次の2つのリストを持っています:
first = [1,2,3,4,5]
second = [6,7,8,9,10]
次に、これらの両方のリストのアイテムを新しいリストに追加します。
出力は
third = [7,9,11,13,15]
このzip
関数はここで役立ち、リスト内包で使用されます。
[x + y for x, y in zip(first, second)]
リストのリストがある場合(2つのリストだけでなく):
lists_of_lists = [[1, 2, 3], [4, 5, 6]]
[sum(x) for x in zip(*lists_of_lists)]
# -> [5, 7, 9]
ドキュメントから
import operator
list(map(operator.add, first,second))
numpy.add
(numpy.subtract
など)のデフォルトの動作は要素ごとです。
import numpy as np
np.add(first, second)
どの出力
array([7,9,11,13,15])
両方のリストが同じ長さであるa
と仮定するとb
、zip、numpyなどは必要ありません。
Python 2.xおよび3.x:
[a[i]+b[i] for i in range(len(a))]
これは、任意の数のリストに拡張されます。
[sum(sublist) for sublist in itertools.izip(*myListOfLists)]
あなたの場合myListOfLists
、[first, second]
次のコードを試してください。
first = [1, 2, 3, 4]
second = [2, 3, 4, 5]
third = map(sum, zip(first, second))
これを行う簡単な方法と迅速な方法は次のとおりです。
three = [sum(i) for i in zip(first,second)] # [7,9,11,13,15]
または、numpysumを使用することもできます。
from numpy import sum
three = sum([first,second], axis=0) # array([7,9,11,13,15])
first = [1, 2, 3, 4, 5]
second = [6, 7, 8, 9, 10]
three = list(map(sum, first, second))
print(three)
# Output
[7, 9, 11, 13, 15]
ワンライナーソリューション
list(map(lambda x,y: x+y, a,b))
同じ長さのリストの数が不明な場合は、以下の関数を使用できます。
ここで、* argsは可変数のリスト引数を受け入れます(ただし、それぞれの要素の数は同じです)。*は、各リストの要素を解凍するために再度使用されます。
def sum_lists(*args):
return list(map(sum, zip(*args)))
a = [1,2,3]
b = [1,2,3]
sum_lists(a,b)
出力:
[2, 4, 6]
または3つのリスト
sum_lists([5,5,5,5,5], [10,10,10,10,10], [4,4,4,4,4])
出力:
[19, 19, 19, 19, 19]
私の答えは、3月17日の9:25に答えたThiruのもので繰り返されます。
それはより簡単で迅速でした、ここに彼の解決策があります:
これを行う簡単な方法と迅速な方法は次のとおりです。
three = [sum(i) for i in zip(first,second)] # [7,9,11,13,15]
または、numpysumを使用することもできます。
from numpy import sum three = sum([first,second], axis=0) # array([7,9,11,13,15])
しびれが必要です!
numpy配列はベクトルのようないくつかの操作を行うことができますimport numpy as np
a = [1,2,3,4,5]
b = [6,7,8,9,10]
c = list(np.array(a) + np.array(b))
print c
# [7, 9, 11, 13, 15]
異なる長さのリストがある場合は、次のようなものを試すことができます(を使用してzip_longest
)
from itertools import zip_longest # izip_longest for python2.x
l1 = [1, 2, 3]
l2 = [4, 5, 6, 7]
>>> list(map(sum, zip_longest(l1, l2, fillvalue=0)))
[5, 7, 9, 7]
を使用zip()
して、2つの配列を「インターリーブ」し、次にmap()
、を使用して、反復可能な各要素に関数を適用できます。
>>> a = [1,2,3,4,5]
>>> b = [6,7,8,9,10]
>>> zip(a, b)
[(1, 6), (2, 7), (3, 8), (4, 9), (5, 10)]
>>> map(lambda x: x[0] + x[1], zip(a, b))
[7, 9, 11, 13, 15]
これを行う別の方法があります。Pythonの内部__add__関数を利用します。
class SumList(object):
def __init__(self, this_list):
self.mylist = this_list
def __add__(self, other):
new_list = []
zipped_list = zip(self.mylist, other.mylist)
for item in zipped_list:
new_list.append(item[0] + item[1])
return SumList(new_list)
def __repr__(self):
return str(self.mylist)
list1 = SumList([1,2,3,4,5])
list2 = SumList([10,20,30,40,50])
sum_list1_list2 = list1 + list2
print(sum_list1_list2)
出力
[11, 22, 33, 44, 55]
リストの残りの値も追加したい場合は、これを使用できます(これはPython3.5で機能しています)
def addVectors(v1, v2):
sum = [x + y for x, y in zip(v1, v2)]
if not len(v1) >= len(v2):
sum += v2[len(v1):]
else:
sum += v1[len(v2):]
return sum
#for testing
if __name__=='__main__':
a = [1, 2]
b = [1, 2, 3, 4]
print(a)
print(b)
print(addVectors(a,b))
first = [1,2,3,4,5]
second = [6,7,8,9,10]
#one way
third = [x + y for x, y in zip(first, second)]
print("third" , third)
#otherway
fourth = []
for i,j in zip(first,second):
global fourth
fourth.append(i + j)
print("fourth" , fourth )
#third [7, 9, 11, 13, 15]
#fourth [7, 9, 11, 13, 15]
これを行う別の方法があります。それは私にとってはうまく機能しています。
N=int(input())
num1 = list(map(int, input().split()))
num2 = list(map(int, input().split()))
sum=[]
for i in range(0,N):
sum.append(num1[i]+num2[i])
for element in sum:
print(element, end=" ")
print("")
j = min(len(l1), len(l2))
l3 = [l1[i]+l2[i] for i in range(j)]
リストをnumpy配列と見なす場合は、リストを簡単に合計する必要があります。
import numpy as np
third = np.array(first) + np.array(second)
print third
[7, 9, 11, 13, 15]
おそらく最も単純なアプローチ:
first = [1,2,3,4,5]
second = [6,7,8,9,10]
three=[]
for i in range(0,5):
three.append(first[i]+second[i])
print(three)
この方法を使用できますが、両方のリストが同じサイズの場合にのみ機能します。
first = [1, 2, 3, 4, 5]
second = [6, 7, 8, 9, 10]
third = []
a = len(first)
b = int(0)
while True:
x = first[b]
y = second[b]
ans = x + y
third.append(ans)
b = b + 1
if b == a:
break
print third