python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python常见错误与解决

Python开发之SMTP连接与字符串处理错误与解决方案

作者:码农阿豪@新空间

在Python开发过程中,开发者经常会遇到各种错误和异常,本文将总结两个典型的Python开发问题,SMTP服务器连接失败和f-string字符串处理错误,有需要的可以参考下

引言

在Python开发过程中,开发者经常会遇到各种错误和异常。有些错误显而易见,例如语法错误;而有些则较为隐蔽,例如网络连接问题或第三方API的限制。本文将总结两个典型的Python开发问题:SMTP服务器连接失败和f-string字符串处理错误,分析其原因,并提供详细的解决方案。文章还将包含代码示例和最佳实践建议,帮助开发者避免类似问题。

1. SMTP服务器连接失败问题

1.1 错误现象

在尝试使用Python的smtplib连接QQ邮箱SMTP服务器时,出现以下错误:

2025-05-15 23:34:58,808 - app - ERROR - SMTP服务器连接失败: (-1, b'\x00\x00\x00')
Traceback (most recent call last):
  File "/doudian-phone-tool/doudian/send_qq_email.py", line 70, in send_email_with_attachment
    with smtplib.SMTP_SSL(smtp_server, smtp_port) as server:
  File "/usr/local/lib/python3.11/smtplib.py", line 284, in __exit__
    raise SMTPResponseException(code, message)
smtplib.SMTPResponseException: (-1, b'\x00\x00\x00')

1.2 可能的原因

1.SMTP服务未开启:QQ邮箱默认关闭SMTP服务,需手动开启。

2.错误的服务器配置:

错误的SMTP服务器地址(如smtp.qq.com拼写错误)

错误的端口号(465或587)

3.授权问题:

使用了邮箱密码而非授权码(QQ邮箱要求使用授权码而非原始密码)

授权码已过期(修改QQ邮箱密码后,授权码会失效)

4.网络或防火墙限制:

服务器无法访问SMTP服务(如云服务器未开放465端口)

本地防火墙或安全组规则阻止连接

1.3 解决方案

(1) 检查并开启QQ邮箱SMTP服务

登录QQ邮箱网页版 → 进入设置 → 账户

找到POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务

开启IMAP/SMTP服务,并生成新的授权码(16位字符串)

(2) 验证SMTP配置

确保代码中的SMTP配置正确:

smtp_server = "smtp.qq.com"  # 必须正确
smtp_port = 465  # SSL端口,或587(STARTTLS)
sender_email = "your_email@qq.com"
password = "your_authorization_code"  # 不是QQ邮箱密码!

(3) 改进错误处理

优化代码,增加更详细的错误日志和重试机制:

import smtplib
import time
from socket import gaierror

​​​​​​​def send_email_with_retry(sender, password, recipients, msg, max_retries=3):
    for attempt in range(max_retries):
        try:
            with smtplib.SMTP_SSL("smtp.qq.com", 465) as server:
                server.login(sender, password)
                server.sendmail(sender, recipients, msg.as_string())
                return True
        except smtplib.SMTPAuthenticationError:
            print("SMTP认证失败:请检查邮箱和授权码")
            return False
        except (smtplib.SMTPException, gaierror) as e:
            print(f"SMTP连接失败(尝试 {attempt + 1}/{max_retries}):{str(e)}")
            time.sleep(2)  # 延迟2秒后重试
    return False

2. f-string字符串引号嵌套错误

2.1 错误现象

在Python代码中使用f-string时,由于引号嵌套错误导致语法错误:

current_app.logger.info(f"【{item['waybillNum']}】运单号,【{record["手机号"]}】手机号处理成功,保存订单到数据库")
                                                                                ^^^^^^^^^
SyntaxError: f-string: unmatched '['

2.2 原因分析

引号冲突:f-string 的外层使用双引号 "...",而内部字典键也使用了双引号 record["手机号"],导致Python解析器无法正确识别字符串边界。

f-string的解析规则:Python的f-string要求引号必须正确配对,否则会抛出SyntaxError。

2.3 解决方案

(1) 外层使用单引号,内层使用双引号

current_app.logger.info(f'【{item["waybillNum"]}】运单号,【{record["手机号"]}】手机号处理成功,保存订单到数据库')

(2) 统一使用单引号

current_app.logger.info(f'【{item[\'waybillNum\']}】运单号,【{record[\'手机号\']}】手机号处理成功,保存订单到数据库')

(3) 使用转义字符

current_app.logger.info(f"【{item['waybillNum']}】运单号,【{record['手机号']}】手机号处理成功,保存订单到数据库")

2.4 最佳实践

优先使用单引号作为字符串分隔符(Python社区推荐)。

避免混用引号,如外层双引号 + 内层双引号。

使用格式化工具(如black或autopep8)自动调整代码风格。

3. 总结与建议

3.1 如何避免类似错误

问题类型预防措施
SMTP连接失败1. 检查SMTP服务是否开启
2. 使用正确的授权码
3. 增加错误重试机制
f-string引号错误1. 统一引号风格
2. 使用代码格式化工具
3. 避免多层嵌套

3.2 调试技巧

日志记录:使用logging模块记录详细错误信息。

逐步测试:先测试SMTP连接(如telnet smtp.qq.com 465),再调试代码。

静态检查:使用pylint或flake8检查语法问题。

到此这篇关于Python开发之SMTP连接与字符串处理错误与解决方案的文章就介绍到这了,更多相关Python常见错误解决内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文