簡體   English   中英

在它們的 int 值之后對 str 進行排序(Python、JSON)

[英]Sort a str after their int value (Python, JSON)

首先:對不起,如果標題具有誤導性,我對術語了解不多。 :/

我的代碼的簡化版本:

import json

y = {}
y['red'] = {'name': "red", 'p': 1}
y['blue'] = {'name': "blue", 'p': 3}
y['green'] = {'name': "green", 'p': 2}

with open('y.json', 'w') as f:
    json.dump(y, f)

f = open('y.json')
y = json.load(f)


z = '%s%s%s' % (y['red']['name'], " ", y['red']['p'])
zz = '%s%s%s' % (y['blue']['name'], " ", y['blue']['p'])
zzz = '%s%s%s' % (y['green']['name'], " ", y['green']['p'])


print(z)
print(zz)
print(zzz)

output 是:

red 1
blue 3
green 2

現在我想在 p 的值之后對 Output 進行排序。 (更大的數字,在 output 中更高。有點像足球中的圖表)所以我想要 output:

blue 3
green 2
red 1

我希望它是自動化的,所以我不只是想寫

print(zz)
print(zzz)
print(z)

在我的原始代碼中,還有不止三個 JSON 值,所以我不想要任何超長的 if 語句。

謝謝:)

而不是使用:

print(z)
print(zz)
print(zzz)

利用:

print('\n'.join(sorted([z, zz, zzz], key=lambda x: int(x.split()[-1]), reverse=True)))

您可以跳過y = json.load(f)之后的部分並使用以下解決方案:

for dct in sorted(y.values(), key=lambda x: x['p'], reverse=True):
    print(dct['name'], dct['p'])

Output:

blue 3
green 2
red 1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM