목차
相关模块
smtplib模块
email模块
几个实例代码
发送普通文本邮件
发送Html格式邮件
发送带附件的邮件
发送带图片的邮件
hello
一个综合示例
代码下载
웹 프론트엔드 HTML 튜토리얼 使用Python发送邮件_html/css_WEB-ITnose

使用Python发送邮件_html/css_WEB-ITnose

Jun 24, 2016 am 11:25 AM

Python是一门很简单和强大的语言,在熟悉其他编程语言的基础上,可以很快的入门Python。Python本身内置了很多工具模块,远比C++方便的多(当然各自的适合场景不同)。

这里简单介绍下我使用python中email模块发送邮件的相关知识。

SMTP是发送邮件的协议,Python内置对SMTP的支持,可以发送纯文本邮件、HTML邮件以及带附件的邮件。python发送邮件主要使用到了smtplib和email两个模块,email负责构造邮件,smtplib负责发送邮件。

相关模块

smtplib模块

smtplib.SMTP()smtplib.SMTP([host[, port[, local_hostname[, timeout]]]])
로그인 후 복사

SMTP类构造函数,表示与SMTP服务器之间的连接,通过这个连接可以向smtp服务器发送指令,执行相关操作(如:登陆、发送邮件)。所有参数都是可选的。参数意义如下:

 host:smtp服务器主机名 port:smtp服务的端口,默认是25;如果在创建SMTP对象的时候提供了这两个参数,在初始化的时候会自动调用connect方法去连接服务器。
로그인 후 복사

smtplib模块还提供了SMTP_SSL类和LMTP类,对它们的操作与SMTP基本一致。

smtplib.SMTP提供的方法:

 SMTP.set_debuglevel(level):#设置是否为调试模式。默认为False,即非调试模式,表示不输出任何调试信息。 SMTP.connect([host[, port]]):#连接到指定的smtp服务器。参数分别表示smpt主机和端口。注意: 也可以在host参数中指定端口号(如:smpt.yeah.net:25),这样就没必要给出port参数。 SMTP.docmd(cmd[, argstring]):向smtp服务器发送指令。可选参数argstring表示指令的参数。 SMTP.helo([hostname]) :使用"helo"指令向服务器确认身份。相当于告诉smtp服务器“我是谁”。 SMTP.has_extn(name):判断指定名称在服务器邮件列表中是否存在。出于安全考虑,smtp服务器往往屏蔽了该指令。 SMTP.verify(address) :判断指定邮件地址是否在服务器中存在。出于安全考虑,smtp服务器往往屏蔽了该指令。 SMTP.login(user, password) :登陆到smtp服务器。现在几乎所有的smtp服务器,都必须在验证用户信息合法之后才允许发送邮件。 SMTP.sendmail(from_addr, to_addrs, msg[, mail_options, rcpt_options]) :发送邮件。这里要注意一下第三个参数,msg是字符串,表示邮件。我们知道邮件一般由标题,发信人,收件人,邮件内容,附件等构成,发送邮件的时候,要注意msg的格式。这个格式就是smtp协议中定义的格式。 SMTP.quit() :断开与smtp服务器的连接,相当于发送"quit"指令。
로그인 후 복사

email模块

emial模块用来处理邮件消息,包括MIME和其他基于RFC 2822 的消息文档。使用这些模块来定义邮件的内容,是非常简单的。其包括的类有( 点此查看更加详细的介绍):

class email.mime.base.MIMEBase(_maintype, _subtype, **_params):这是MIME的一个基类。一般不需要在使用时创建实例。其中_maintype是内容类型,如text或者image。_subtype是内容的minor type 类型,如plain或者gif。 **_params是一个字典,直接传递给Message.add_header()。class email.mime.multipart.MIMEMultipart([_subtype[, boundary[, _subparts[, _params]]]]:MIMEBase的一个子类,多个MIME对象的集合,_subtype默认值为mixed。boundary是MIMEMultipart的边界,默认边界是可数的。class email.mime.application.MIMEApplication(_data[, _subtype[, _encoder[, **_params]]]):MIMEMultipart的一个子类。class email.mime.audio. MIMEAudio(_audiodata[, _subtype[, _encoder[, **_params]]]): MIME音频对象class email.mime.image.MIMEImage(_imagedata[, _subtype[, _encoder[, **_params]]]):MIME二进制文件对象。class email.mime.message.MIMEMessage(_msg[, _subtype]):具体的一个message实例.class email.mime.text.MIMEText(_text[, _subtype[, _charset]]):MIME文本对象,其中_text是邮件内容,_subtype邮件类型,可以是text/plain(普通文本邮件),html/plain(html邮件),  _charset编码,可以是gb2312等等。
로그인 후 복사

几个实例代码

发送普通文本邮件

#!/usr/bin/env python# -*- coding: utf-8 -*-import smtplibfrom email.mime.text import MIMETextfrom email.Header import Headerdef sendMailText(title, content, sender, receiver, serverip, serverport, username, pwd):    msg = MIMEText(content, _subtype="plain", _charset="utf-8")    # 设置正文为符合邮件格式的HTML内容    msg['Subject'] = Header(title, "utf-8")     # 设置邮件标题    msg['From'] = sender                        # 设置发件人    msg['To'] = receiver                        # 设置收件人    s = smtplib.SMTP(serverip, serverport)      # 注意!如果是使用SSL端口,这里就要改为SMTP_SSL    #s.ehlo()    #s.starttls()    s.login(username, pwd)                      # 登陆邮箱    s.sendmail(sender, receiver, msg.as_string())  # 发送邮件if __name__ == "__main__":    config = {    "from": "XXXXXXXXX@163.com",            # 发件人邮箱    "to": "YYYYYYYYYY@163.COM",             # 收件人邮箱    "serverip": "smtp.163.com",             # 发件服务器IP    "serverport":"25",                      # 发件服务器Port    "username": "XXXXXXXXX@163.com",        # 发件人用户名    "pwd": "AAAAAAAAAAAAAA"                 # 发件人密码    }    title = "python send mail"    body = "<a href='http://cpper.info'>cpper</a>"    sendMailText(title, body, config['from'], config['to'], config['serverip'], config['serverport'], config['username'], config['pwd'])
로그인 후 복사

发送Html格式邮件

与上面介绍的文本邮件基本一致,除了一点不同:

msg = MIMEText(content, _subtype="html", _charset="utf-8")
로그인 후 복사

发送带附件的邮件

如果发送带附件的邮件,首先要创建MIMEMultipart()实例,然后构造附件,如果有多个附件,可依次构造,最后利用smtplib.smtp发送。

def sendMailWithAttachment(title, content, sender, receiver, serverip, serverport, username, pwd, attach = {}):    attachsize = len(attach)    if attachsize > 0 :        print 'send attach'        msg = MIMEMultipart()   #创建一个带附件的实例        for path, name in attach.items():            print path, name            if os.path.exists(path):                att = MIMEText(open(path, 'rb').read(), 'base64', 'gb2312')   #构造附件                att["Content-Type"] = 'application/octet-stream'                att["Content-Disposition"] = 'attachment; filename="' + name + '"'                msg.attach(att)                # http://help.163.com/09/1224/17/5RAJ4LMH00753VB8.html 提示发送病毒或垃圾邮件 554, 'DT:SPM 163    else:        msg = MIMEText(content, _subtype="html", _charset="utf-8")    # 设置正文为符合邮件格式的HTML内容    msg['Subject'] = Header(title, "gb2312")    # 设置邮件标题    msg['From'] = sender                        # 设置发件人    msg['To'] = receiver                        # 设置收件人    s = smtplib.SMTP(serverip, serverport)      # 注意!如果是使用SSL端口,这里就要改为SMTP_SSL    s.login(username, pwd)                      # 登陆邮箱    s.sendmail(sender, receiver, msg.as_string())  # 发送邮件attach = {}  # key : 要发送的文件,需要存在,否则读取不到:value :自定义发送邮件中的文件名attach['sendEmail.py'] = '1.py'  attach['memset.cpp'] = '2.c'#attach['noexist.cpp'] = '3.cpp'sendMailWithAttachment(title, body, config['from'], config['to'], config['serverip'], config['serverport'], config['username'], config['pwd'], attach)
로그인 후 복사

发送带图片的邮件

def sendMailWithImage(title, content, sender, receiver, serverip, serverport, username, pwd, images = []):    imagesize = len(images)    if imagesize > 0 :        msg = MIMEMultipart()   #创建一个带附件的实例        for path in images:            print path            if os.path.exists(path):                image = MIMEImage(open(path,'rb').read())                name = path.split(os.sep)[-1]                image.add_header("Content-Disposition", "attachment", filename=name)                image.add_header('Content-ID', '<0>')                image.add_header('X-Attachment-Id', '0')                    # We reference the image in the IMG SRC attribute by the ID we give it below                         #msg.attach(MIMEText('

hello

' + '

使用Python发送邮件_html/css_WEB-ITnose

' + '', 'html', 'utf-8')) msg.attach(image) else: msg = MIMEText(content, _subtype="html", _charset="utf-8") # 设置正文为符合邮件格式的HTML内容 msg['Subject'] = Header(title, "gb2312") # 设置邮件标题 msg['From'] = sender # 设置发件人 msg['To'] = receiver # 设置收件人 s = smtplib.SMTP(serverip, serverport) # 注意!如果是使用SSL端口,这里就要改为SMTP_SSL s.login(username, pwd) # 登陆邮箱 s.sendmail(sender, receiver, msg.as_string()) # 发送邮件
로그인 후 복사

一个综合示例

# 发送含有各种元素的邮件def sendMail(title, content, sender, receiver, serverip, serverport, username, pwd, attach = {}, images = {}):    msg = MIMEMultipart()    msg['Subject'] = Header(title, "utf-8")     # 设置邮件标题    msg['From'] = sender                        # 设置发件人    msg['To'] = receiver                        # 设置收件人    #msg['To'] = ";".join(receiver)             # 多个收件人    attachsize = len(attach)    if attachsize > 0 :        print 'send attach'        for path, name in attach.items():            3print path, name            if os.path.exists(path):                att = MIMEText(open(path, 'rb').read(), 'base64', 'gb2312')   #构造附件                att["Content-Type"] = 'application/octet-stream'                att["Content-Disposition"] = 'attachment; filename="' + name + '"'                print att["Content-Disposition"]                msg.attach(att)    imagesize = len(images)    if imagesize > 0 :        for path, name in images.items():            #print path, name            if os.path.exists(path):                image = MIMEImage(open(path,'rb').read())                #image = MIMEImage(open(path,'rb').read(), _subtype="jpg")                image.add_header("Content-Disposition", "attachment", filename=name)                image.add_header('Content-ID', '<0>')                image.add_header('X-Attachment-Id', '0')                msg.attach(image)    s = smtplib.SMTP(serverip, serverport)      # 注意!如果是使用SSL端口,这里就要改为SMTP_SSL    s.login(username, pwd)                      # 登陆邮箱    s.sendmail(sender, receiver, msg.as_string())  # 发送邮件if __name__ == "__main__":    config = {        "from": "XXXXXXXXX@163.com",            # 发件人邮箱        "to": "YYYYYYYYYY@163.COM",             # 收件人邮箱        "serverip": "smtp.163.com",             # 发件服务器IP        "serverport":"25",                      # 发件服务器Port        "username": "XXXXXXXXX@163.com",        # 发件人用户名        "pwd": "AAAAAAAAAAAAAA"                 # 发件人密码    }    title = "python send mail"    body = "<a href='http://cpper.info'>cpper</a>"    attach = {}  # key : 要发送的文件,需要存在,否则读取不到:value :自定义发送邮件中的文件名    attach['sendEmail.py'] = '1.py'      attach['memset.cpp'] = '2.c'    attach['noexist.cpp'] = '3.cpp'    images = {}    images['lizheng3.jpg'] = '1.jpg'    sendMail(title, body, config['from'], config['to'], config['serverip'], config['serverport'], config['username'], config['pwd'], attach, images)
로그인 후 복사

代码下载

本文所有代码可以点此下载:sendEmail.py。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

& lt; Progress & Gt의 목적은 무엇입니까? 요소? & lt; Progress & Gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:34 PM

이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

& lt; datalist & gt의 목적은 무엇입니까? 요소? & lt; datalist & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:33 PM

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

& lt; meter & gt의 목적은 무엇입니까? 요소? & lt; meter & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:35 PM

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? Mar 17, 2025 pm 12:20 PM

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? Mar 17, 2025 pm 12:27 PM

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

뷰포트 메타 태그는 무엇입니까? 반응 형 디자인에 중요한 이유는 무엇입니까? 뷰포트 메타 태그는 무엇입니까? 반응 형 디자인에 중요한 이유는 무엇입니까? Mar 20, 2025 pm 05:56 PM

이 기사는 모바일 장치의 반응 형 웹 디자인에 필수적인 Viewport Meta Tag에 대해 설명합니다. 적절한 사용이 최적의 컨텐츠 스케일링 및 사용자 상호 작용을 보장하는 방법을 설명하는 반면, 오용은 설계 및 접근성 문제로 이어질 수 있습니다.

html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? Mar 12, 2025 pm 04:05 PM

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.

& lt; iframe & gt; 꼬리표? 보안을 사용할 때 보안 고려 사항은 무엇입니까? & lt; iframe & gt; 꼬리표? 보안을 사용할 때 보안 고려 사항은 무엇입니까? Mar 20, 2025 pm 06:05 PM

이 기사는 & lt; iframe & gt; 외부 컨텐츠를 웹 페이지, 공통 용도, 보안 위험 및 객체 태그 및 API와 같은 대안을 포함시키는 태그의 목적.

See all articles