Кортежи Python: сравнивать и объединять без циклов for - PullRequest
0 голосов
/ 08 июня 2018

У меня есть два списка по 100 000 кортежей в каждом.В первом списке кортежей есть две строки, во второй - пять.Каждый кортеж в первом списке имеет кортеж с общим значением в другом списке.Например,

tuple1 = [('a','1'), ('b','2'), ('c','3')]
tuple2 = [('$$$','a','222','###','HHH'), ('ASA','b','QWER','TY','GFD'), ('aS','3','dsfs','sfs','sfs')] 

У меня есть функция, которая может удалять избыточные значения кортежей и сопоставлять важную информацию:

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

, которая должна возвращать:

 final_list = [('a','1','222','###','HHH'), ('b','2','QWER','TY','GFD'), ('c','3','dsfs','sfs','sfs')]

Однако списки безумно длинные.Есть ли способ обойти вычислительное время цикла for при сравнении и сопоставлении значений кортежей?

Ответы [ 2 ]

0 голосов
/ 08 июня 2018

Используя словарь, это можно сделать в O (n)

dict1 = dict(tuple1)
final_list =  [(tup[1],dict[tup[1]])+ tup[1:] for tup in tuple2]
0 голосов
/ 08 июня 2018
tuple1 = [('a','1'), ('b','2'), ('c','3')]
tuple2 = [('$$$','a','222','###','HHH'), ('ASA','b','QWER','TY','GFD'), ('aS','3','dsfs','sfs','sfs')]

def match_comment_and_thread_data(tuple1, tuple2):
    i = 0
    out_thread_dict = dict([(b, (c, d, e)) for a, b, c, d, e in tuple2])
    final_list = [x + out_thread_dict.get(x[0],out_thread_dict.get(x[1])) for x in tuple1]
    return final_list

при использовании словаря вместо этого ваше время поиска равно O (1) ... вам все равно нужно посетить каждый элемент в списке1 ... но совпадение быстрое ... хотя вам нужно больше значений, чем 3чтобы получить выгоду

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...