gpt4 book ai didi

python - 如何根据另一个列表中的项目从嵌套列表创建第三个列表

转载 作者:行者123 更新时间:2023-12-01 06:56:31 24 4
gpt4 key购买 nike

我有一些用户的列表

list_of_users=['@elonmusk', '@YouTube','@FortniteGame','@BillGates','@JeffBezos']

以及由推文组成的嵌套列表,按单词分割。

tweets_splitted_by_words=[['@MrBeastYT', '@BillGates', 'YOU’RE', 'THE', 'LAST', 'ONE', 'FINISH', 'THE', 'MISSION', '#TeamTrees'], ['@MrBeastYT', '@realDonaldTrump', 'do', 'something', 'useful', 'with', 'your', 'life', 'and', 'donate', 'to', '#TeamTrees'], ['Please', 'please', 'donate']]

仅当每个子列表至少包含 list_of_users 中的一个用户时,我才想创建由 tweets_splitted_by_words 的子列表创建的第三个新列表。我想要的输出:

output=[['@MrBeastYT', '@BillGates', 'YOU’RE', 'THE', 'LAST', 'ONE', 'FINISH', 'THE', 'MISSION', '#TeamTrees']]

我尝试了以下代码,但没有成功:

tweets_per_user_mentioned= []
giorgia=[]
for r in range(len(tweets_splitted_by_words)):
giorgia.append(r)
for _i in range(len(giorgia)):
if _i in range(len(list_of_users)):
tweets_per_user_mentioned.append(tweets_splitted_by_words[r])
else:
pass
print(tweets_per_user_mentioned)

最佳答案

由于您将在用户列表上执行查找,因此最好使用 set 数据结构。 Sets provide O(1) lookup这大大降低了许多问题的时间复杂度。

对于过滤,我只使用 python 的内置 any和列表理解

set_of_users = set(list_of_users)
filtered_tweets = [tweet for tweet in tweets_splitted_by_words \
if any(word in set_of_users for word in tweet)]

关于python - 如何根据另一个列表中的项目从嵌套列表创建第三个列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58783487/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com