Вы можете выполнить итерацию по вашему lic
и сравнить каждый из его элементов с duplicates
, и, если найдете совпадение, заменить этот элемент первым элементом соответствующего кортежа.
lic = ['GPLv2', ' & ', 'LGPLv2+', ' & ', 'LGPLv2.1+', ' | ', 'LGPLv3+']
duplicates = (
('GPL-2.0', 'GPL-2', 'GPLv2', 'GPLv2.0'),
('GPL-2.0+', 'GPL-2+', 'GPLv2+', 'GPLv2.0+'),
('GPL-3.0', 'GPL-3', 'GPLv3', 'GPLv3.0'),
('GPL-3.0+', 'GPL-3+', 'GPLv3+', 'GPLv3.0+'),
('LGPL-2.0', 'LGPLv2.0', 'LGPLv2', 'LGPL2'),
('LGPL-2.0+', 'LGPLv2.0+', 'LGPLv2+', 'LGPL2+'),
('LGPL-2.1', 'LGPLv2.1', 'LGPL2.1'),
('LGPL-2.1+', 'LGPLv2.1+', 'LGPL2.1+'),
('LGPL-3.0', 'LGPLv3.0', 'LGPLv3', 'LGPL3'),
('LGPL-3.0+', 'LGPLv3.0+', 'LGPLv3+', 'LGPL3+')
)
for idx, i in enumerate(lic):
for match in duplicates:
if i in match:
lic[idx] = match[0]
break
print(lic)
Вывод:
['GPL-2.0', ' & ', 'LGPL-2.0+', ' & ', 'LGPL-2.1+', ' | ', 'LGPL-3.0+']