пытается отправить xlsx с Python - PullRequest
1 голос
/ 11 октября 2019

Я пытаюсь отправить электронное письмо с прикрепленным к нему файлом xlsx, я сделал / отформатировал xlsx с помощью xlsxwriter, каждый раз, когда я отправляю его со своим кодом, xlsx теряет все форматирование / цвета / функции, добавленные другим моим кодом.

from string import Template
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.base import MIMEBase
from email import encoders

MY_ADDRESS = 'myemail'

def get_contacts(filename):
    names = []
    emails = []
    with open(filename, mode='r', encoding='utf-8') as contacts_file:
        for a_contact in contacts_file:
            names.append(a_contact.split()[0])
            emails.append(a_contact.split()[1])
    return names, emails



def read_template(filename):
    with open(filename, 'r', encoding='utf-8') as template_file:
        template_file_content = template_file.read()
    return Template(template_file_content)


def main():
    names, emails = get_contacts('mycontacts.txt') # read contacts
    message_template = read_template('message.txt')

    # set up the SMTP server
    s = smtplib.SMTP(host='my.smpt.server')
#    s.starttls()
    #s.login(MY_ADDRESS, PASSWORD)

    # For each contact, send the email:
    for name, email in zip(names, emails):
        msg = MIMEMultipart()       # create a message

        # add in the actual person name to the message template
        message = message_template.substitute(PERSON_NAME=name.title())

        # Prints out the message body for our sake
        print(message)

        # setup the parameters of the message
        msg['From']=MY_ADDRESS
        msg['To']=email
        msg['Subject']="This is TEST"

        # add in the message body
        msg.attach(MIMEText(message, 'plain'))


        part = MIMEBase('application', "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
        part.set_payload(open("my_filename.xlsx", "rb").read())
        encoders.encode_base64(part)
        part.add_header('Content-Disposition', 'attachment; filename="my_filename.xlsx"')
        msg.attach(part)

        # send the message via the server set up earlier.
        s.send_message(msg)
        del msg

    # Terminate the SMTP session and close the connection
    s.quit()

if __name__ == '__main__':
    main()

Я попытался найти много, и это работает для всех, но для меня, может быть, проблема в том, что я отформатировал мой файл с помощью xlsx. Также, когда я отправляю файл через bash с помощью команды mail, файл сохраняет все форматирование

...