假设我的字典是这样的:

{
    "432701228292636694" : {
        "64AEdcb" : {
            "inviter" : "282764296075870208",
            "uses" : 40
        },
        "9WVmh3Q" : {
            "inviter" : "173219378492473345",
            "uses" : 26
        },
        "AE8ugEN" : {
            "inviter" : "285548207189000204",
            "uses" : 4
        },
        "EmCddbN" : {
            "inviter" : "193926566881918978",
            "uses" : 2
        },
        "GKnPWyW" : {
            "inviter" : "147756076299845632",
            "uses" : 1
        },
        "JnmyFKE" : {
            "inviter" : "173219378492473345",
            "uses" : 10
        },
        "Km4wZTz" : {
            "inviter" : "161132853256650752",
            "uses" : 9
        },
        "M8uYMNb" : {
            "inviter" : "193896125969858561",
            "uses" : 8
        },
        "e9vTXcz" : {
            "inviter" : "273852837988007936",
            "uses" : 1
        },
        "gTB7w4R" : {
            "inviter" : "327660257423917066",
            "uses" : 1
        },
        "hG2KyZa" : {
            "inviter" : "315630485114191872",
            "uses" : 2
        },
        "pdZNPFa" : {
            "inviter" : "141431182792458241",
            "uses" : 537
        },
        "rZwH4QF" : {
            "inviter" : "384664458628169728",
            "uses" : 4
        },
        "s9FXVAU" : {
            "inviter" : "125092433657593856",
            "uses" : 2
        },
        "wrPbkGz" : {
            "inviter" : "277605262486011904",
            "uses" : 3
        }
    }
}

我想把每个键的总数加起来,得到一个组合的总数。在上述数据中,使用26和10的“173219378492473345”键。我想把它合并成36。
我怎样才能做到这一点?我可以写一个清单理解陈述,可以让我得到每一个的价值,但把它们加在一起,得到一个总数是我迷路的地方。
下面的代码是我已经写过的:
codes = sorted(self.invites_db[server.id], key=lambda x: (self.invites_db[server.id][x]['uses']), reverse=True)
inviters = [server.get_member(self.invites_db[server.id][x]['inviter']).name + "#" + server.get_member(self.invites_db[server.id][x]['inviter']).discriminator for x in codes if self.invites_db[server.id][x]['inviter'] != "141431182792458241"]
uses = [self.invites_db[server.id][x]['uses'] for x in codes if self.invites_db[server.id][x]['inviter'] != "141431182792458241"]

这将给我一个所有inviteruses的列表,但我不希望有两个相同的inviters,而是希望它们作为一个被添加到一起。我如何才能做到这一点,以便他们能够使用inviters以文本格式并排显示此数据?

最佳答案

collections.Counter对于那些“算我或零”的东西/积累问题(你不能用列表理解来解决):

result = collections.Counter()
for subdict in d["432701228292636694"].values():
    result[subdict["inviter"]] += subdict["uses"]

结果:
>>> result
{'125092433657593856': 2,
 '141431182792458241': 537,
 '147756076299845632': 1,
 '161132853256650752': 9,
 '173219378492473345': 36,
 '193896125969858561': 8,
 '193926566881918978': 2,
 '273852837988007936': 1,
 '277605262486011904': 3,
 '282764296075870208': 40,
 '285548207189000204': 4,
 '315630485114191872': 2,
 '327660257423917066': 1,
 '384664458628169728': 4}

关于python - 将具有相同键字符串的多个字典键值加在一起,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/52983386/

10-13 03:42