Лучший способ дедупликации моей адресной книги Thunderbird?
У меня есть куча повторяющихся контактов в моей адресной книге Thunderbird. Я не хочу делиться ими с Google, но я хочу найти способ их обмануть. Был подключен дублирующий менеджер контактов, но, похоже, он был заброшен.
Могу ли я сделать это в командной строке?
1 ответ
У меня была такая же проблема несколько лет назад, и я написал очень маленький скрипт на python для унификации экспорта в LDIF адресной книги Thunderbird:
- экспортировать адресную книгу в формате LDIF, например, в abook.ldif
- бегать
cat abook.ldif | unify_ldif.py > abook_new.ldif
- снова импортировать abook_new.ldif (возможно, переименовать старую адресную книгу раньше)
В настоящее время сценарий сопоставляет повторяющиеся записи на адрес электронной почты и идентичное имя, но это, конечно, можно адаптировать (в функции find_existing_entry
). Это работает для вас?
Программа здесь (РЕДАКТИРОВАТЬ: вам нужно python-ldap
упаковка):
#!/usr/bin/env python
import sys
from ldif import LDIFParser, LDIFWriter
def find_existing_entry(ldif_entries, ldif_entry):
for dn, entry in ldif_entries.items():
if 'mail' in ldif_entry and 'mail' in entry:
for mail in ldif_entry['mail']:
if 'mail' in entry and mail in entry['mail']:
return dn
if 'cn' in ldif_entry and 'cn' in entry and ldif_entry['cn'][0] in entry['cn']:
return dn
if 'sn' in ldif_entry and 'sn' in entry and 'givenName' in ldif_entry and 'givenName' in entry and ldif_entry['sn'][0] in entry['sn'] and ldif_entry['givenName'][0] in entry['givenName']:
return dn
return ''
class MyLDIF(LDIFParser):
def __init__(self, input, output):
LDIFParser.__init__(self, input)
self.writer = LDIFWriter(output)
self.entries = {}
def merge(self, dn, entry):
if 'mail' in entry.keys():
if 'mail' in self.entries[dn].keys():
for mail in entry['mail']:
if mail not in self.entries[dn]['mail']:
self.entries[dn]['mail'].append(mail)
else:
self.entries[dn]['mail'] = entry['mail']
for key in entry.keys():
if key not in self.entries[dn].keys():
self.entries[dn][key] = entry[key]
def handle(self, dn, entry):
if dn in self.entries.keys():
self.merge(dn, entry)
else:
found_dn = find_existing_entry(self.entries, entry)
if found_dn != '':
self.merge(found_dn, entry)
else:
self.entries[dn] = entry
def output(self):
for dn, entry in self.entries.items():
self.writer.unparse(dn, entry)
parser = MyLDIF(sys.stdin, sys.stdout)
parser.parse()
parser.output()