|
@@ -62,32 +62,26 @@ class Material():
|
|
|
|
|
|
data = [json.loads(item) for item in data]
|
|
|
|
|
|
-
|
|
|
+
|
|
|
groups = defaultdict(lambda: defaultdict(list))
|
|
|
for item in data:
|
|
|
- groups[item['keyword_name']][item['channel_id']].append(item)
|
|
|
+ groups[item['channel_id']][item['keyword_name']].append(item)
|
|
|
|
|
|
-
|
|
|
- unique_names = list(groups.keys())
|
|
|
- priority_names = [name for name in unique_names if name in unique_names]
|
|
|
- remaining_names = [name for name in unique_names if name not in priority_names]
|
|
|
+
|
|
|
+ unique_channel_ids = list(groups.keys())
|
|
|
|
|
|
-
|
|
|
result = []
|
|
|
- max_length = max(len(groups[name][channel]) for name in priority_names for channel in groups[name])
|
|
|
|
|
|
- for i in range(max_length):
|
|
|
- for name in priority_names:
|
|
|
- channels = list(groups[name].keys())
|
|
|
- channel_index = i % len(channels)
|
|
|
- channel = channels[channel_index]
|
|
|
- if i < len(groups[name][channel]):
|
|
|
- result.append(groups[name][channel][i])
|
|
|
+
|
|
|
+ max_length = max(len(groups[channel][keyword]) for channel in unique_channel_ids for keyword in groups[channel])
|
|
|
|
|
|
-
|
|
|
- for name in remaining_names:
|
|
|
- for channel in groups[name]:
|
|
|
- result.extend(groups[name][channel])
|
|
|
+ for i in range(max_length):
|
|
|
+ for channel in unique_channel_ids:
|
|
|
+ keywords = list(groups[channel].keys())
|
|
|
+ keyword_index = i % len(keywords)
|
|
|
+ keyword = keywords[keyword_index]
|
|
|
+ if i < len(groups[channel][keyword]):
|
|
|
+ result.append(groups[channel][keyword][i])
|
|
|
|
|
|
|
|
|
sorted_list = [json.dumps(item, ensure_ascii=False) for item in result]
|