Я изучаю Python, и мое первое задание - преобразовать файл в формате Zimbra zmprov
в csv
и ldif
.
Поскольку я не знаю встроенных функций Python для выполнения задачиЯ беру долгий путь и перебираю строки и печать.
Я был бы очень признателен, если бы вы, ребята, смогли показать мне, как это сделать правильно.
Это входные данные zmp_file,для преобразования в csv и ldif
ca user1@domain.com.br ''
ma user1@domain.com.br cn 'User One'
ma user1@domain.com.br cpf ''
ma user1@domain.com.br l 'Porto Alegre'
ca user2@domain.com.br ''
ma user2@domain.com.br cn 'User Two'
ma user2@domain.com.br cpf '0123456789'
ma user2@domain.com.br l ''
Требуемый вывод .csv (порядок полей не важен)
mail,cn,cpf,l
user1@domain.com.br,"User One",,"Porto Alegre"
user2@domain.com.br,"User Two",0123456789,
И желаемый вывод .ldif (порядок полейне важно)
dn: 'uid=user1@domain.com.br'
cn: 'User One'
l: 'Porto Alegre'
mail: 'user1@domain.com.br'
dn: 'uid=user2@domain.com.br'
cn: 'User Two'
cpf: '0123456789'
mail: 'user2@domain.com.br'
Как далеко я мог бы пройти:
with zmp_file as input_file
for line in input_file:
if line.startswith('ca'):
mail = line.split()[1]
print "dn: uid={0}".format(mail)
print "mail: {0}".format(mail)
elif line.startswith('ma'):
words = shlex.split(line)[-2:]
print "{0}: {1}".format(words[0], words[1])
else:
print