Я создал два списка, назовите их «а» и «б». Список a имеет длину 24 480, а длина b — 20 116. Каждый элемент как в a, так и в b также является списком длиной 3. Для наглядности каждый элемент этих списков выглядит так:
Код: Выделить всё
a = [str1a, str2a, float1a]
b = [str1b, str2b, float1b]
Что мне нужно сделать, так это проверить, есть ли str1a == str1b и str2a == str2b, а затем изменить значение float1a в результате получается float1a * float1b. В списке b есть дубликаты, и не каждый элемент обязательно будет совпадать.
Я попробовал это с помощью цикла, который работает и получает то, что мне нужно.
Код: Выделить всё
for i in range(0, len(a)):
for n in range(0, len(b)):
if a[i][0] == b[n][0] and a[i][1] == b[n][1]:
a[i][2] *= b[n][2]
Однако мне бы хотелось получить тот же результат, но (более быстрым) и более эффективным способом. В идеале я придерживаюсь методов на основе Python — я бы предпочел не решать эту проблему импортом каких-либо модулей.
Подробнее здесь:
https://stackoverflow.com/questions/790 ... g-for-matc