python发送多人邮件没有展示收件人问题的解决方法

作者:jwensh 时间:2023-01-03 05:16:10 

背景:

工作过程中需要对现有的机器、服务做监控,当服务出现问题后,邮件通知对应的人

问题:

使用python 2.7自带的email库来进行邮件的发送,但是发送后没有展示收件人列表内容

问题代码示例:


# -*- coding:utf-8 -*-
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText

def send_email_to(fromAdd, toAdd, subject, html_text, filename):
server = 'mail.****.com'
user = '*****'
password = '********'

strFrom = fromAdd
strTo = toAdd

msgRoot = MIMEMultipart('related')
msgRoot['Subject'] = subject
msgRoot.preamble = 'This is a multi-part message in MIME format.'

msgAlternative = MIMEMultipart('alternative')
msgRoot.attach(msgAlternative)

msgText = MIMEText(html_text, 'html', 'utf-8')
msgAlternative.attach(msgText)

smtp = smtplib.SMTP()
smtp.connect(server)
smtp.login(user, passwd)

att5 = MIMEText(open(filename, 'rb').read(), 'base64', 'utf-8')
att5["Content-Type"] = 'application/octet-stream'
att5["Content-Disposition"] = 'attachment; filename="fail_7_storage.txt"'
msgRoot.attach(att5)

smtp.sendmail(strFrom, strTo, msgRoot.as_string())
smtp.quit()
return

成功代码:


#!/usr/bin/env python
# -*- coding: utf-8 -*-

import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.utils import parseaddr
from email.utils import formataddr
from email.header import Header

def __format_addr__(addr):
# 解析邮件地址,以保证邮有别名可以显示
alias_name, addr = parseaddr(addr)
# 防止中文问题,进行转码处理,并格式化为str返回
return formataddr((Header(alias_name,charset="utf-8").encode(),
     addr.encode("uft-8") if isinstance(addr, unicode) else addr))

def send_email_to(fromAdd, toAdd, subject, html_text, filename=None):

SERVER = 'mail.***.com'
USER = '******'
PASSWD = '***'

strFrom = __format_addr(fromAdd)

strTo = list()
# 原来是一个纯邮箱的list,现在如果是一个["jayzhen<jayzhen@jz.com>"]的list给他格式化
try:
 for a in toAdd:
  strTo.append(__format_addr(a))
except Exception as e:
 # 没有对a和toadd进行type判断,出错就直接还原
 strTo = toAdd

msgRoot = MIMEMultipart('related')
msgRoot.preamble = 'This is a multi-part message in MIME format.'

msgAlternative = MIMEMultipart('alternative')
msgRoot.attach(msgAlternative)

# 邮件对象
msgText = MIMEText(html_text, 'html', 'utf-8')
msgRoot['Subject'] = Header(subject) # 这是邮件的主题,通过Header来标准化
msgRoot['From'] = strFrom  # 发件人也是被格式化过的
msgRoot['to'] = ','.join(strTo) # 这个一定要是一个str,不然会报错“AttributeError: 'list' object has no attribute 'lstrip'”
msgAlternative.attach(msgText)

smtp = smtplib.SMTP(SERVER, 11)
smtp.set_debuglevel(0)
# smtp.connect(SERVER)
smtp.login(USER, PASSWD)
# 这里要注意了,这里的fromadd和toAdd和msgRoot['From'] msgRoot['to']的区别
smtp.sendmail(fromAdd, toAdd, msgRoot.as_string())
smtp.quit()

总结:

看到 msgRoot['to'] = ','.join(strTo)  与  msgRoot['to'] = strTo

实验过程中发现这个["to"]一定要是一个str,不然会报错“AttributeError: 'list' object has no attribute 'lstrip'”

同时也发现["to"]的数据类型与sendmail(from_addrs,to_addrs,...)的to_addrs不同;前者为str类型,多个地址使用逗号分隔,后者为list类型

还有就是MIMEText、MIMEMultipart他们之间的关系,可以看一哈源码,他们算是兄弟关系,都是继承MIMEBase,那么这是时候,["From"]、["to"]等这些属性给谁都行。

来源:https://blog.csdn.net/u013948858/article/details/82903977

标签:python,发送邮件
0
投稿

猜你喜欢

  • 详解Python的Django框架中inclusion_tag的使用

    2021-05-19 13:10:26
  • Oracle中的分析函数汇总

    2024-01-20 05:59:38
  • python 类的继承 实例方法.静态方法.类方法的代码解析

    2021-12-19 14:19:34
  • SQL Server 1069错误(由于登录失败而无法启动服务)解决方法

    2008-09-12 17:35:00
  • MySQL中导出用户权限设置的脚本分享

    2024-01-21 15:29:04
  • MySQL中InnoDB的间隙锁问题

    2024-01-25 11:13:58
  • 巧用JDBC实现对MySQL的“增删改查”

    2008-12-31 15:12:00
  • MySQL中使用case when 语句实现多条件查询的方法

    2024-01-16 17:17:31
  • Python短信轰炸的代码

    2022-11-03 17:35:04
  • Python3打包exe代码2种方法实例解析

    2022-03-31 14:36:30
  • python 异常的传递性及主动抛出学习

    2021-03-19 05:02:38
  • 错误的随机数_JavaScript

    2009-08-28 12:43:00
  • JavaScript字符串对象toLowerCase方法入门实例(用于把字母转换为小写)

    2024-05-08 10:10:47
  • python计算程序开始到程序结束的运行时间和程序运行的CPU时间

    2023-08-04 02:11:09
  • 验证码的最高境界

    2008-05-08 14:17:00
  • python命令行参数解析OptionParser类用法实例

    2022-06-21 17:57:24
  • python ddt实现数据驱动

    2021-11-11 02:37:08
  • python3 QT5 端口转发工具两种场景分析

    2023-04-03 10:34:46
  • processlist命令 查看mysql 线程

    2024-01-24 02:58:30
  • 浅谈mysql中concat函数,mysql在字段前/后增加字符串

    2024-01-22 10:06:53
  • asp之家 网络编程 m.aspxhome.com