我有一個字典,其中有兩個字串“Candy-one”和“Candy-two”作為鍵,容量作為鍵對。我希望將字串“Candy-one”和“Candy-two”替換為在“Candy-one”和“Candy-two”的相同位置具有相同糖果的 Brand-Name
這是我嘗試過的
p = [['Brand-Name', 'Swap', ' Candy-one ', ' Candy-two ', 'Capacity'],
['Willywonker', 'Yes', 'bubblegum', 'mints', '7'],
['Mars-CO', 'Yes', 'chocolate', 'bubblegum', '1'],
['Nestle', 'Yes', 'bears', 'bubblegum', '2'],
['Uncle Jims', 'Yes', 'chocolate', 'bears', '5']]
f = {('bubblegum', 'mints'): 4,
('chocolate', 'bubblegum'): 1,
('bears', 'bubblegum'): 2,
('chocolate', 'bears'): 2}
def Brand(f,p):
i = 0
while i < len(p)-1:
i = i 1
for key in f:
print(key[0])
print(key[1])
if key[0] == p[i][2] and key[1] == p[i][3]:
f[p[i][0]] = key.pop(key)
return f
print(brand(f,p))
這是我的輸出
{('bubblegum', 'mints'): 4,
('chocolate', 'bubblegum'): 1,
('bears', 'bubblegum'): 2,
('chocolate', 'bears'): 2}
好像什么都沒發生這就是我想要的輸出
{'Willywonker': 4,
'Mars-CO': 1,
'Nestle': 2,
'Uncle Jims': 2}
uj5u.com熱心網友回復:
使用雙回圈效率不高(二次復雜度)。
以下是我將如何解決它:
def Brand(f,p):
# create a mapping dictionary
d = {tuple(x[2:4]): x[0] for x in p[1:]}
# output a new dictionary with replaced keys
# or old key if a new one is not found
return {d.get(k, k): v for k,v in f.items()}
# or if you want to drop in case of no match
# return {d[k]: v for k,v in f.items() if k in d}
Brand(f,p)
輸出:
{'Willywonker': 4,
'Mars-CO': 1,
'Nestle': 2,
'Uncle Jims': 2}
uj5u.com熱心網友回復:
def Brand(f,p):
res={}
i = 0
while i < len(p)-1:
for key in f:
if key[0] == p[i 1][2] and key[1] == p[i 1][3]:
res[p[i 1][0]] = f[key]
i = 1
return res
new_dict = Brand(f,p)
print(new_dict)
{'Willywonker': 4, 'Mars-CO': 1, 'Nestle': 2, 'Uncle Jims': 2}
或者您更正的嘗試:
def Brand(f,p):
res=f.copy()
i = 0
while i < len(p)-1:
for key in f:
if key[0] == p[i 1][2] and key[1] == p[i 1][3]:
res[p[i 1][0]] = res.pop(key)
i = 1
return res
updated_dict = Brand(f,p)
print(updated_dict)
{'Willywonker': 4, 'Mars-CO': 1, 'Nestle': 2, 'Uncle Jims': 2}
uj5u.com熱心網友回復:
key
,作為一個元組,沒有pop
方法,這表明你從來沒有真正嘗試過改變f
(也許是因為你從來沒有打電話Brand
)。
加上@quamrana 指出的東西。
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/470687.html
上一篇:嵌套for回圈中向量之間的計算