回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我有两个超过100000元组的列表。第一个元组列表中有两个字符串,后者有五个字符串。第一个列表中的每个元组都有一个元组,另一个列表中有一个公共值。例如</p>
<pre><code>tuple1 = [('a','1'), ('b','2'), ('c','3')]
tuple2 = [('$$$','a','222','###','HHH'), ('ASA','b','QWER','TY','GFD'), ('aS','3','dsfs','sfs','sfs')]
</code></pre>
<p>我有一个函数,可以删除多余的元组值并匹配重要信息:</p>
<pre><code>def match_comment_and_thread_data(tuple1, tuple2):
i = 0
out_thread_tuples = [(b, c, d, e) for a, b, c, d, e in tuple2]
print('Out Thread Tuples Done')
final_list = [x + y for x in tuple2 for y in tuple1 if x[0] == y[0]]
return final_list
</code></pre>
<p>应该返回:</p>
<pre><code> final_list = [('a','1','222','###','HHH'), ('b','2','QWER','TY','GFD'), ('c','3','dsfs','sfs','sfs')]
</code></pre>
<p>然而,名单却长得离谱。在比较和匹配元组值时,有没有办法绕过for循环的计算时间承诺?你知道吗</p>