以下是一个示例代码,演示了如何按固定分类选择前几个结果,将剩余的结果归入其他分类:
def classify_results(results, categories, num_top_results):
classified_results = {}
other_results = []
for category in categories:
classified_results[category] = []
for result in results:
if result['category'] in categories:
classified_results[result['category']].append(result)
else:
other_results.append(result)
for category in categories:
classified_results[category] = sorted(classified_results[category], key=lambda x: x['score'], reverse=True)[:num_top_results]
return classified_results, other_results
# 示例数据
results = [
{'id': 1, 'category': 'A', 'score': 0.9},
{'id': 2, 'category': 'B', 'score': 0.8},
{'id': 3, 'category': 'A', 'score': 0.7},
{'id': 4, 'category': 'C', 'score': 0.6},
{'id': 5, 'category': 'B', 'score': 0.5},
{'id': 6, 'category': 'C', 'score': 0.4},
{'id': 7, 'category': 'A', 'score': 0.3},
{'id': 8, 'category': 'B', 'score': 0.2},
{'id': 9, 'category': 'C', 'score': 0.1}
]
categories = ['A', 'B', 'C']
num_top_results = 2
classified_results, other_results = classify_results(results, categories, num_top_results)
print("Classified Results:")
for category, results in classified_results.items():
print("Category:", category)
for result in results:
print(result)
print("\nOther Results:")
for result in other_results:
print(result)
这个示例代码中,classify_results
函数接受一个结果列表 results
,一个分类列表 categories
,以及一个整数 num_top_results
,并返回一个字典 classified_results
和一个列表 other_results
。
classified_results
包含按分类分类的前 num_top_results
个结果,other_results
包含剩余的结果。
在示例数据中,结果列表包含了一些分类为 'A'
、'B'
和 'C'
的结果。函数首先创建一个空字典 classified_results
和一个空列表 other_results
。
然后,它遍历结果列表,并根据结果的分类将结果添加到 classified_results
字典的相应分类中,如果分类不在 categories
列表中,则将结果添加到 other_results
列表中。
接下来,函数对 classified_results
字典中的每个分类的结果进行排序,并保留前 num_top_results
个结果。
最后,函数返回 classified_results
字典和 other_results
列表。
在示例代码的最后,我们打印出分类的结果和其他的结果,以验证代码的正确性。