我正在开发一个大型项目,其中包括一个用于记住用户的数据库。 il跳过细节,但我的客户希望我能够包含一个功能,他可以备份所有用户数据和其他文件。
我在考虑一封电子邮件,(因为该项目是一个Android应用程序),我试图弄清楚如何在电子邮件中发送一个附件(即.db sqlite3文件)。我知道在here周围有很多类似的问题,但this问题的所有答案都给了我一个错误。这是我最接近的地方:
此程序发送没有附件的电子邮件:
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
boodskap = MIMEText("Toekomsweb Epos toets", 'plain')
van_adres = "from adres"
na_adres = "to adres"
epos_liggaam = MIMEMultipart('alternatief')
epos_liggaam['Subject'] = "Toets"
epos_liggaam['From'] = van_adres
epos_liggaam['To'] = na_adres
epos_liggaam.attach(boodskap)
mail = smtplib.SMTP('smtp.gmail.com',587)
mail.ehlo()
mail.starttls()
mail.login(van_adres,'PASSWORD')
mail.sendmail(van_adres,na_adres,epos_liggaam.as_string())
mail.close()
print("succes!")
请原谅我糟糕的变量命名,不是英文。
发送附件的任何帮助?
谢谢!
答案 0 :(得分:0)
嗨,这是我使用的代码......事实证明,ubunto使用不同的方式发送电子邮件而不是Windows。
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.base import MIMEBase
from email import encoders
import os
boodskap = MIMEText("Toekomsweb Epos toets", 'plain')
van_adres = 'From adres'
na_adres = 'To adres'
epos_liggaam = MIMEMultipart('alternatief')
epos_liggaam['Subject'] = "Toets"
epos_liggaam['From'] = van_adres
epos_liggaam['To'] = na_adres
epos_liggaam.attach(boodskap)
f = "toets.db"
part = MIMEBase('application', "octet-stream")
part.set_payload( open(f,"rb").read() )
encoders.encode_base64(part)
part.add_header('Content-Disposition', 'attachment; filename="{0}"'.format(os.path.basename(f)))
epos_liggaam.attach(part)
mail = smtplib.SMTP('smtp.gmail.com',587)
mail.ehlo()
mail.starttls()
mail.login(van_adres,'PASSWORD')
mail.sendmail(van_adres,na_adres,epos_liggaam.as_string())
mail.close()
print("succes!")
这个答案改编自here(第二个答案)
希望这个答案能够回答别人的问题