我正在尝试从列表中创建密钥对,然后将它们附加到列表中。但是,它返回一个空列表。
Combined = {}
Awarded = []
Keys = Contract_Keys + Details_Keys
Values = Contract_Values + Details_Values
#Create key pairs with multiple lists
Combined = dict(zip(Keys, Values))
#Append to the Awarded table
Awarded.append(Combined)
Final = pd.DataFrame(Awarded)
注意:我已经将代码更改为上面的代码,以便实际上可以返回非空集。但是我现在遇到的问题是,当我压缩并决定键和值时,结果是奇怪的:
Combined = dict(zip([a,b],[1,2]))应该为[a:1,b:2]时返回为[a1:1,b2:2)。为何将“值”与“键”字段中的“键”连接起来?
答案 0 :(得分:0)
不知道这是您之后的目标吗,但是我能够通过列表理解做到这一点?
Combined = {}
Awarded = []
#Created some test dictionaries
dictOne = {"k1" : "v1","k2" : "v2","k3" : "v3","k4" : "v4" }
dictTwo = {"k5" : "v5","k6" : "v6","k7" : "v7","k8" : "v8" }
#Got the keys
Contract_Keys = [keys for keys in dictOne]
Details_Keys = [keys for keys in dictTwo]
#Got the values
Contract_Values = [dictOne[values] for values in dictOne]
Details_Values = [dictTwo[values] for values in dictTwo]
########output###########
#['k1', 'k2', 'k3', 'k4']
#['k5', 'k6', 'k7', 'k8']
#['v1', 'v2', 'v3', 'v4']
#['v5', 'v6', 'v7', 'v8']
#Concat lists
Keys = Contract_Keys + Details_Keys
Values = Contract_Values + Details_Values
#Combined lists into single dictionary
Combined = dict(zip(Keys, Values))
#Combined kvp from dict into a list of lists
Awarded = [[key, Combined[key]] for key in Combined]
#########output#########
#[['k1', 'v1'], ['k2', 'v2'], ['k3', 'v3'], ['k4', 'v4'], ['k5', 'v5'],
#['k6', 'v6'], ['k7', 'v7'], ['k8', 'v8']]
#{'k1': 'v1', 'k2': 'v2', 'k3': 'v3', 'k4': 'v4', 'k5': 'v5', 'k6': 'v6',
#'k7': 'v7', 'k8': 'v8'}