如何从数据库发送电子邮件

编程入门 行业动态 更新时间:2024-10-10 02:23:37
本文介绍了如何从数据库发送电子邮件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我已使用Send email from Databricks Notebook with attachment中的代码尝试从我的Databricks社区版发送代码:

我使用了以下代码:

import smtplib from pathlib import Path from email.mime.multipart import MIMEMultipart from email.mime.base import MIMEBase from email.mime.text import MIMEText from email.utils import COMMASPACE, formatdate from email import encoders from_email = "myname@myemail.co.uk" to_email = "myname@myemail.co.uk" def send_mail(send_from = from_email, send_to = to_email, subject = "Test", message = "Test", files=["/FileStore/tables2/"], server="smtp.hosts.co.uk", port=587, username='myusername.co.uk', password='!L3qGWGuyw', use_tls=True): msg = MIMEMultipart() msg['From'] = send_from msg['To'] = COMMASPACE.join(send_to) msg['Date'] = formatdate(localtime=True) msg['Subject'] = subject msg.attach(MIMEText(message)) for path in files: part = MIMEBase('application', "octet-stream") with open(path, 'rb') as file: part.set_payload(file.read()) encoders.encode_base64(part) part.add_header('Content-Disposition', 'attachment; filename="{}"'.format(Path(path).name)) msg.attach(part) smtp = smtplib.SMTP(server, port) if use_tls: smtp.starttls() smtp.login(username, password) smtp.sendmail(send_from, send_to, msg.as_string()) smtp.quit()

如您所见,代码几乎完全相同。但是,当我运行代码时,我得到以下错误:

FileNotFoundError: [Errno 2] No such file or directory: '/FileStore/tables2/'

此错误是否也是因为我运行的是数据库社区版,就像上一个问题中的情况一样。

推荐答案

/FileStore/tables2/只是要作为附件发送的文件的名称。您需要在那里输入您的文件名,或者如果您不想发送附件,请将列表设置为空。它应该是本地文件,因此在Azure上使用/dbfs/....,在社区版上-使用dbutils.fs.cp to copy file from DBFS to local file system。

更多推荐

如何从数据库发送电子邮件

本文发布于:2023-10-12 16:14:45,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1485240.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:发送电子邮件   数据库

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!