lst1 = ['company1,AAA,7381.0 ', 'company1,BBB,-8333.0 ', 'company1,CCC,
3079.999 ', 'company1,DDD,5699.0 ', 'company1,EEE,1640.0 ',
'company1,FFF,-600.0 ', 'company1,GGG,3822.0 ', 'company1,HHH,-600.0 ',
'company1,JJJ,-4631.0 ', 'company1,KKK,-400.0 ']
lst2 =['company1,AAA,-4805.0 ', 'company1,ZZZ,-2576.0 ', 'company1,BBB,1674.0 ', 'company1,CCC,3600.0 ', 'company1,DDD,1743.998 ']
輸出我需要==蟒蛇添加兩個列表和createing一個新的列表
['company1,AAA,2576.0','company1,ZZZ,-2576.0 ','company1,KKK,-400.0 ' etc etc]
我需要添加它類似的產品數量在每個列表並將其移動到一個新的列表。我還需要將任何符號添加到新列表中。我在瀏覽每個列表時遇到問題。
這是我有:
h = []
z = []
a = []
for g in lst1:
spl1 = g.split(",")
h.append(spl1[1])
for j in lst2:
spl2 = j.split(",")
**if spl2[1] in h:
converted_num =(float(spl2[2]) +float(spl1[2]))
pos=('{0},{1},{2}'.format(spl2[0],spl2[1],converted_num))
z.append(pos)**
else:
pos=('{0},{1},{2}'.format(spl2[0],spl2[1],spl2[2]))
z.append(pos)
for f in z:
spl3 = f.split(",")
a.append(spl3[1])
for n in lst1[:]:
spl4 = n.split(",")
if spl4[1] in a:
got = (spl4[0],spl4[1],spl4[2])
lst1.remove(n)
smash = lst1+z #for i in smash:
for i in smash:
print(i)
我有問題通過列表迭代,以確保我得到的所有simliar產品的一個新的列表,(粗體)和任何產品不在列表中的1但是在第一個到新的列表中,反之亦然。我相信有一個更簡單的方法。
燦」你在這裏用字典嗎? –
而不是'spl2 = j.split(「,」)'你可能想要做'公司名稱,字母,值= j.split(「,」)' –
我可以,但我需要最終的輸出在列表中與所有的產品和金額,如lst1和lst2以上 –