-1

我有一个 dict 包含产品的列表:

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']}] 

和一个 dict 列表包含 tax :

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])
4

2 回答 2

0

经过艰苦的搜索,我找到了回应:

sum([item['amount']*tax['amount'] for item in products if 'tva' in item['tax'] for tax in taxes if tax['name']=='tva'])
于 2016-07-10T11:01:35.960 回答
0

dict 包含税的列表只有两个值。您可以使用 adict而不是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'

于 2016-05-25T11:59:22.160 回答