0

我今天早些时候问了这个问题: Evaluating values within a dictionary for different keys

我正在使用的字典的结构已经改变,我试图修改我得到的解决方案以适应这种情况。

之前的结构是:

locsOne = {1: [100], 2: [200], 3: [250]}

但现在它已更改为:

locsone = {1: [[100]], 2: [[200]], 3: [[250]]}

我正在尝试在 locsOne 字典上应用半正弦公式,获取键:值与另一个键:值的距离,如果它们大于 450,则不应将它们包含在结果字典中。

生成的字典应如下所示:

locsTwo = {1: {2: 100, 3: 150}, 2: {1: 100, 3: 50}, 3: {1: 150, 2: 50}}

这是我收到的代码(感谢 falsetru):

for k1 in locsOne:
    v1 = locsOne[k1][0]
    locsTwo[k1] = {k2: abs(v1 - locsOne[k2][0]) for k2 in locsOne
                   if k1 != k2 and abs(v1 - locsOne[k2][0]) <= 450}
print(locsTwo)

我尝试修改它会返回错误,例如“IndexError: list out of range”和“KeyError”。

我最后的修改是:

for k1 in locsOne:
        v1 = locsOne[k1][1]
        locsTwo[k1] = {k2: harvesineForm(v1 , locsOne[k2][1]) for k2 in locsOne
                   if k1 != k2 and abs(v1 - locsOne[k2][0]) <= 450}

任何帮助将不胜感激。

4

1 回答 1

0
a = [[100]]
print a       # [[100]]
print a[0]    # [100]
print a[0][0] # 100

假设值总是在列表中包含单个值,嵌套在列表中:

locsOne = {1: [[100]], 2: [[200]], 3: [[250]]}
locsTwo = {}

for k1 in locsOne:
    v1 = locsOne[k1][0][0]
    locsTwo[k1] = {k2: abs(v1 - locsOne[k2][0][0]) for k2 in locsOne
                   if k1 != k2 and abs(v1 - locsOne[k2][0][0]) <= 450}
print(locsTwo)

您只需再次访问[0]列表的第一个值 ( ),因为您还有一个级别的列表。

于 2014-08-31T20:23:15.823 回答