輸入字典
d = {'PQR':{"LMN":1.345,'PST':1.278,'BQR':2.345,'RMT':9.867},
'HGE':{'VRM':1.765,'TRM':1.567,'FRM':1.456,'DRM':1.678}}
有沒有辦法使用這個公式來規范 [0,1] 范圍內的嵌套字典值
(value - min(x))/(max(x)- min(x))
但是,對于規范化,最小值和最大值應該在每個內部字典中找到。預期產出
output = {'PQR':{"LMN":0.0078006752823378675,'PST':0.0,'BQR':0.12422866457096288,'RMT':1.0},
'HGE':{'VRM':1.0,'TRM':0.3592233009708738,'FRM':0.0,'DRM':0.7184466019417476}}
uj5u.com熱心網友回復:
您可以回圈內部字典并相應地對其進行變異。下面的示例方法:
d = {'PQR': {"LMN": 1.345, 'PST': 1.278, 'BQR': 2.345, 'LMN': 9.867},
'HGE': {'VRM': 1.765, 'TRM': 1.567, 'FRM': 1.456, 'DRM': 1.678}}
# Find the normalized value
fn = lambda value, x_max, x_min: (value - x_min) / (x_max - x_min)
# In each inner dict
for _d in d.values():
# find min and max values
max_x = max(_d.values())
min_x = min(_d.values())
# normalize each value in the dict
for k, v in _d.items():
_d[k] = fn(v, max_x, min_x)
print(d)
為您提供如下輸出:
{'PQR': {'LMN': 1.0, 'PST': 0.0, 'BQR': 0.12422866457096288}, 'HGE': {'VRM': 1.0, 'TRM': 0.3592233009708738, 'FRM': 0.0, 'DRM': 0.7184466019417476}}
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/471997.html