您的位置:首页 >Python发Gmail无错误但未送达解决方法
发布于2026-01-20 阅读(0)
扫一扫,手机访问

本文旨在解决使用Python `smtplib`库通过Gmail发送邮件时,脚本运行无错误但邮件实际未送达的常见问题。核心原因通常在于Gmail严格的安全设置。教程将详细指导如何正确配置Gmail账户(特别是使用应用密码),并提供示例代码和全面的排查步骤,确保Python脚本能成功发送邮件。
在使用Python的smtplib库结合Gmail服务发送邮件时,开发者常会遇到一个令人困惑的问题:脚本执行顺利,没有任何错误信息抛出,但收件箱中却迟迟不见邮件的踪影。这种“静默失败”往往不是代码本身的语法错误,而是与Gmail的安全策略和账户配置紧密相关。理解并正确配置这些安全设置,是解决此类问题的关键。
Gmail为了保护用户账户安全,对通过第三方应用(如Python脚本)发送邮件实施了严格的控制。这通常是导致邮件无法发送的根本原因。
如果您的Gmail账户启用了两步验证(2FA),那么尝试使用您的常规Gmail密码通过smtplib进行登录将会失败,即使密码本身是正确的。在这种情况下,您需要生成并使用“应用密码”。应用密码是一个16位的代码,它授权非Google应用或设备访问您的Google账户。
如何生成应用密码:
在过去,Gmail提供了一个“低安全性应用访问”的选项,允许那些不支持OAuth 2.0等现代安全协议的应用访问您的账户。然而,Google已于2022年5月30日永久关闭了此功能。因此,对于新账户或已启用两步验证的账户,此选项不再可用或不推荐使用。如果您的账户仍然能够访问此设置(这极不可能),并且未启用两步验证,开启它可能会解决问题,但这不是一个推荐的安全实践。对于大多数用户而言,应用密码是唯一且安全的解决方案。
以下是一个典型的Python smtplib发送邮件的结构,我们将在此基础上进行优化和排查。
对于Gmail,SMTP服务器地址是smtp.gmail.com。端口通常使用587(配合STARTTLS加密)或465(配合SSL加密)。
email.mime.multipart.MIMEMultipart和email.mime.text.MIMEText是构建复杂邮件内容的常用模块。它们允许您设置发件人、收件人、主题,并附加邮件正文。
使用server.login(sender_email, sender_password)进行身份验证。这里的sender_password就是您的Gmail应用密码。最后,通过server.sendmail(sender_email, recipient_email, msg.as_string())发送邮件。
以下是根据问题描述提供的代码进行优化和注释的示例,着重强调了使用应用密码和必要的smtplib配置。
import pandas as pd
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
import ssl # 用于更明确的SSL/TLS上下文
# --- 配置信息 ---
# 邮件发送方凭据
sender_email = "your_email@gmail.com" # 替换为您的Gmail邮箱
sender_password = "your_app_password" # 替换为您的Gmail应用密码 (重要!)
# 邮件内容
subject = "Python smtplib 教程邮件"
body = "您好,这是一封通过Python smtplib发送的测试邮件。"
# 收件人信息 (从Excel文件读取,此处为示例)
# 假设 Excel 文件 'AAAAAA.xlsx' 的第一列包含收件人邮箱
excel_file = "C:\\Users\\YourUsername\\Downloads\\AAAAAA.xlsx" # 请替换为您的实际路径
try:
df = pd.read_excel(excel_file)
# 假设邮箱地址在第一列 (索引为0)
email_addresses = df.iloc[:, 0].dropna().astype(str).values.flatten()
if not email_addresses.size:
print("警告: Excel文件中未找到有效的收件人邮箱。")
email_addresses = ["test_recipient@example.com"] # 提供一个备用地址用于测试
except FileNotFoundError:
print(f"错误: Excel文件 '{excel_file}' 未找到。请检查路径。")
email_addresses = ["test_recipient@example.com"] # 提供一个备用地址用于测试
except Exception as e:
print(f"读取Excel文件时发生错误: {e}")
email_addresses = ["test_recipient@example.com"] # 提供一个备用地址用于测试
# --- SMTP服务器设置 ---
smtp_server = "smtp.gmail.com"
smtp_port = 587 # 通常使用587端口配合STARTTLS
# --- 发送邮件逻辑 ---
try:
# 创建一个安全的SSL上下文
context = ssl.create_default_context()
# 连接到SMTP服务器
# 使用with语句确保连接正确关闭
with smtplib.SMTP(smtp_server, smtp_port) as server:
# 启用TLS加密
server.starttls(context=context)
# 登录到Gmail账户
server.login(sender_email, sender_password)
print(f"成功登录到Gmail账户: {sender_email}")
# 遍历所有收件人并发送邮件
for email_address in email_addresses:
msg = MIMEMultipart()
msg['From'] = sender_email
msg['To'] = email_address
msg['Subject'] = subject
msg.attach(MIMEText(body, 'plain'))
try:
server.sendmail(sender_email, email_address, msg.as_string())
print(f"成功发送邮件至: {email_address}")
except smtplib.SMTPRecipientsRefused as e:
print(f"发送至 {email_address} 失败: 收件人被拒绝。错误: {e}")
except smtplib.SMTPDataError as e:
print(f"发送至 {email_address} 失败: 数据错误 (如邮件大小限制)。错误: {e}")
except Exception as e:
print(f"发送至 {email_address} 时发生未知错误: {e}")
except smtplib.SMTPAuthenticationError:
print("错误: 认证失败。请检查您的Gmail邮箱和应用密码是否正确。")
print("如果您启用了两步验证,请确保使用应用密码而非常规密码。")
except smtplib.SMTPConnectError as e:
print(f"错误: 无法连接到SMTP服务器。请检查网络连接和SMTP服务器地址/端口。错误: {e}")
except Exception as e:
print(f"发送邮件过程中发生未知错误: {e}")
print("邮件发送尝试完成。")即使启用了应用密码,有时邮件仍可能无法发送。以下是一些额外的排查步骤:
凭据核查:
网络与防火墙:
Gmail账户活动:
日志记录:
Python smtplib与Gmail邮件发送静默失败的根本原因,绝大多数情况下都归结于Gmail严格的安全策略。通过为启用了两步验证的Gmail账户生成并使用应用密码,可以有效解决认证问题。同时,确保代码中的SMTP服务器配置正确,并结合本文提供的排查步骤,能够帮助您快速定位并解决邮件发送问题,实现Python脚本与Gmail的顺畅通信。
上一篇:今日头条如何隐藏关注列表?
下一篇:360浏览器截图快捷键及技巧大全
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9