Что надо сделать, для сбора вложений(прайс-листы) с email и последующей передачей по ftp?
На почту приходят прайс-листы, некоторые в архивах, некоторые по ссылках, надо автоматически их распаковать, перевести в csv, и далее по ftp раскидать по папках
Вы же всё написали. Пишите скрипт, который по расписанию или когда вам надо получает почту, смотрит текст и вложения, скачивает по ссылке прайс или распаковывает архив, переводит в нужный формат, подключается к фтп серверу и раскидывает куда надо. В чём суть вопроса? В интернете найдёте примеры как почту получать, как архивы распаковывать и так далее
Привет, вопрос по imaplib, все ли я правильно прописал?
spoiler
import imaplib
import email
import os
user = 'ex@gmail.com'
password = '*******'
imap_url = 'imap.gmail.com'
attachment_dir = 'C:/Users/admin/Documents/Attachment'
def auth(user,password,imap_url):
con = imaplib.IMAP4_SSL(imap_url)
con.loggin(user,password)
return con
def get_body(msg):
if msg.is_multipart():
return get_body(msg.get_payload(0))
else:
return msg.get_payload(None,True)
def get_attachments(msg):
for part in msg.walk():
if part.get_content_maintype() == 'multipart':
continue
if part.get('Content-Disposition') is None:
continue
fileName = part.get_filename()
if bool(fileName):
filePath = os.path.join(attachment_dir, fileName)
with open(filePath, 'wb') as f:
f.write(part.get_payload(decode=True))
def search(key,value,con):
result, data = con.search(None,key,'"{}'.format(value))
return data
def get_emails(result_bytes):
msgs = []
for num in result_bytes[0].split():
typ, data = con.fetch(num, '(RFC822)')
msgs.append(data)
return msgs
con = auth(user,password,imap_url)
con.select('INBOX')
result, data = con.fetch(b'10','(RFC822)')
raw = email.message_from_bytes(data[0][1])
get_attachments(raw)