我有一个包含产品的字典列表:
products = [{'name' : 'art1','amount':2000, 'qty':2, 'tax':['tax_15', 'tva']} ,
{'name' : 'art2','amount':2500, 'qty':3, 'tax':['tax_15', 'timbre']},
{'name' : 'art3','amount':3000, 'qty':4, 'tax':['tva']}]
字典列表包含税收:
taxes = [{'name' : 'tax_15','amount':15} ,
{'name' : 'tva','amount':17},
{'name' : 'timbre','amount':10}]
我想计算所有产品的 tva,在这个例子中,tva 只存在于 art1 和 art3 中,在这种情况下:
tva = (2000 * 17%) + (3000 * 17%)
我想在一行 python 代码中计算 tva,我尝试了这一行:
sum([t['amount']*t['qty']*tax_of_tva_if_exist_in_this_product for t in products])
dict 包含税收的列表只有两个值。您可以使用dict
而不是list
。重建您的税收清单以指示税,其中使用name
作为关键
taxes_dict = {}
for tax in taxes:
taxes_dict[tax['name']] = tax
因此,您可以在一行中计算 tva,以便:
sum([t[amount]*t[qty]*taxes_dict['tva']['amount'] if 'tva' in t['tax'] else 0 for t in products])
P/S:请再次检查您的列表。 name
,qty
和tax
应该是'name'
、'qty'
和'tax'
经过硬搜索,我找到了响应:
sum([item['amount']*tax['amount'] for item in products if 'tva' in item['tax'] for tax in taxes if tax['name']=='tva'])