Я более свежий в Python3 и теперь застрял в одной проблеме.
Постановка проблемы: у меня есть defaultdict, который имеет несколько значений для одного ключа. В этих множественных значениях есть похожие и разные значения.
Теперь я хотел бы получить сводку (количество подсчетов на основе уникальных записей) для каждого ключа.
словарь (с именем «d»), как показано ниже defaultdict(, {'0': ['"126"},', '"115"},', '"60"},'], '1': [' "126"},'], '2': ['"126"},', '"126"},', '"126"},', '"148"},', '"99"} ,'], '3': ['"126"},', '"226"},'], '4': ['"126"},', '"90"},'], })
Ожидаемый результат:
0: countALL :3; 1: countALL :1; 2: countALL :3; 3: countALL :2; 4: countALL :2;
Как, например, для ключа «2» есть 3 записи из 126, 1 из 148 и 1 из 99. Таким образом, итог будет равен 3, поскольку существует три типа уникальных записей.
Это для программы Python3 для моего исследования, которое я использую для различения трафика разных типов, поступающего из сети.
Ожидаемый результат:
0: countALL :3; 1: countALL :1; 2: countALL :3; 3: countALL :2; 4: countALL :2;
Можете ли вы очистить свои входы и выходы? Сначала вы упоминаете, что у вас есть defaultdict, над которым вам нужно выполнять операции подсчета, но затем в своем примере кода вы используете набор. Пример кода не должен нигде печатать countAll
, но вы предполагаете, что это так.
Дамиано С., ваше решение также сработало. были небольшие отличия от того, что я ожидал. ваш код давал общее количество, основанное на записях, но я ожидал получить только количество, основанное только на разных значениях/записях. Просто близко к ожидаемому. Спасибо за ваши усилия.
Вот ответ на мою интерпретацию вашего вопроса, хотя моя интерпретация может быть неверной.
from collections import Counter
data = {1: [2,3,4,3,4], 2: [6,5,3,5]}
for key, values in data.items():
print(f'{key} has the following unique counts {Counter(values)}')
который выводит следующее:
1 has the following unique counts Counter({3: 2, 4: 2, 2: 1})
2 has the following unique counts Counter({5: 2, 6: 1, 3: 1})
Вывод правильно дает детали. Но мне нужно, чтобы получить количество уникальных предметов. т. е. 1 имеет следующий тип уникальных счетчиков Counter (3)
Ах, в таком случае вы можете сделать print(f'{key} has {len(Counter(values))} unique items')
. Если вы найдете этот ответ полезным, не забудьте проголосовать/отметить его как решение.
Да, это отлично сработало и получило именно то, что я хотел. Спасибо за вашу большую поддержку.
попробуйте вместо этого
counts = {k: len(v) for k, v in d.items()}