[英]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.