`
huangro
  • 浏览: 333375 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

python模块之email: 电子邮件编码解码(转)

阅读更多
出处:http://blog.csdn.net/zhaoweikid/archive/2007/06/01/1634766.aspx

python自带的email模块是个很有意思的东西,它可以对邮件编码解码,用来处理邮件非常好用。
处理邮件是一个很细致的工作,尤其是解码邮件,因为它的格式变化太多了,下面先看看一个邮件的源文件:
Received: from 192.168.208.56 ( 192.168.208.56 [192.168.208.56] ) by
ajax-webmail-wmsvr37 (Coremail) ; Thu, 12 Apr 2007 12:07:48 +0800 (CST)
Date: Thu, 12 Apr 2007 12:07:48 +0800 (CST)
From: user1 <xxxxxxxx@163.com>
To: zhaowei <zhaoweikid@163.com>
Message-ID: <31571419.200911176350868321.JavaMail.root@bj163app37.163.com>
Subject: =?gbk?B?u+nJtA==?=
MIME-Version: 1.0
Content-Type: multipart/Alternative;
    boundary="----=_Part_21696_28113972.1176350868319"

------=_Part_21696_28113972.1176350868319
Content-Type: text/plain; charset=gbk
Content-Transfer-Encoding: base64

ztLS0b+qyrzS1M6qysfSu7j20MfG2ru70ru0zqOs1K3AtMrH0ru49tTCtffSu7TOztLDx8/W1NrT
prjDysew67XjssXE3MjI1ebC6bezICAg
------=_Part_21696_28113972.1176350868319
Content-Type: text/html; charset=gbk
Content-Transfer-Encoding: quoted-printable

<DIV>=CE=D2=D2=D1=BF=AA=CA=BC=D2=D4=CE=AA=CA=C7=D2=BB=B8=F6=D0=C7=C6=DA=BB=
=BB=D2=BB=B4=CE=A3=AC=D4=AD=C0=B4=CA=C7=D2=BB=B8=F6=D4=C2=B5=F7=D2=BB=B4=CE=
</DIV>
<DIV>=CE=D2=C3=C7=CF=D6=D4=DA=D3=A6=B8=C3=CA=C7=B0=EB=B5=E3=B2=C5=C4=DC=C8=
=C8</DIV>
<DIV>=D5=E6=C2=E9=B7=B3</DIV>
------=_Part_21696_28113972.1176350868319--

    上面的就是以封邮件的源文件,从第一行到第一个空行之间的为信件头,后面的就是信件体了。把上面的信息复制下来存到一个叫xxx.eml的文件里,用鼠标双击就可以看到内容,当然看到的是解码后的,是outlook帮你解码了。
    看看email模块怎么处理这个邮件,假设信件已经存为xxx.eml。

#-*- encoding: gb2312 -*-
import email

fp = open("xxx.eml", "r")
msg = email.message_from_file(fp) # 直接文件创建message对象,这个时候也会做初步的解码
subject = msg.get("subject") # 取信件头里的subject, 也就是主题
# 下面的三行代码只是为了解码象=?gbk?Q?=CF=E0=C6=AC?=这样的subject
h = email.Header.Header(subject)
dh = email.Header.decode_header(h)
subject = dh[0][0]
print "subject:", subject
print "from: ", email.utils.parseaddr(msg.get("from"))[1] # 取from
print "to: ", email.utils.parseaddr(msg.get("to"))[1] # 取to

fp.close()


这段代码可以把一封邮件中的主题、发件人、收件人解析出来。email.utils.parseaddr是用来专门解析邮件地址的,原因是邮件地址很多时候在原文里是这样写的:user1 <xxxxxxxx@163.com>, email.utils.parseaddr就可以把它解析为一个列表,第一项是user1, 第二项是xxxxxxxx@163.com, 这里只显示了后面以部分。
    前面那段代码只是解析了信件头,接着解析信件体吧。信体里可能有纯文本的plain和html两部分,也可能有附件。这里需要mime的知识,详细介绍可以从网上搜搜。我这里就不说了,下面看看怎么解析的:
#-*- encoding: gb2312 -*-
import email

fp = open("xxx.eml", "r")
msg = email.message_from_file(fp)

# 循环信件中的每一个mime的数据块
for par in msg.walk():
    if not par.is_multipart(): # 这里要判断是否是multipart,是的话,里面的数据是无用的,至于为什么可以了解mime相关知识。
         name = par.get_param("name") #如果是附件,这里就会取出附件的文件名
        if name:
            #有附件
            # 下面的三行代码只是为了解码象=?gbk?Q?=CF=E0=C6=AC.rar?=这样的文件名
             h = email.Header.Header(name)
             dh = email.Header.decode_header(h)
             fname = dh[0][0]
            print '附件名:', fname
             data = par.get_payload(decode=True) # 解码出附件数据,然后存储到文件中
            
            try:
                 f = open(fname, 'wb') #注意一定要用wb来打开文件,因为附件一般都是二进制文件
            except:
                print '附件名有非法字符,自动换一个'
                 f = open('aaaa', 'wb')
             f.write(data)
             f.close()
        else:
            #不是附件,是文本内容
            print par.get_payload(decode=True) # 解码出文本内容,直接输出来就可以了。
        
        print '+'*60 # 用来区别各个部分的输出n"]


简单吧,并没有多少代码就可以实现复杂的解析邮件的功能!

分享到:
评论

相关推荐

    Python使用email模块对邮件进行编码和解码的实例教程

    Python的email模块是处理电子邮件的强大工具,它支持邮件的编码和解码,使得开发者能够方便地解析和构建邮件消息。本教程将详细讲解如何使用email模块来处理邮件的编码转换和解码。 邮件的格式通常遵循RFC 5322标准...

    Python 标准库学习.zip

    20. **email模块**:处理电子邮件消息,包括解析、创建和发送邮件。 通过深入学习Python标准库,你可以掌握各种常用功能,提高编程效率,并能更好地应对各种项目需求。无论是新手还是经验丰富的开发者,了解并熟练...

    Python-将MicrosoftOutlookmsg文件转换为emlMIME消息文件的Python库

    在电子邮件处理领域,Python库提供了便利的工具来处理不同格式的邮件文件。本篇文章将详细探讨如何使用Python将Microsoft Outlook的.msg文件转换为.eml或MIME消息文件。 首先,.msg文件是Microsoft Outlook中用于...

    python标准库.pdf_Python标准库_

    19. **email模块**:处理电子邮件消息,包括编码、解码、解析邮件头和正文。 20. **xml.etree.ElementTree模块**:XML处理,用于解析和生成XML文档,简化XML操作。 Python标准库中的每个模块都有其特定的用途,...

    Python标准库(中文版).zip

    15. **email模块**:处理电子邮件消息,包括编码和解码、解析邮件头和正文等。 通过阅读这个中文版的标准库文档,开发者不仅可以了解每个模块的用途,还能学习如何正确地使用它们,提升Python编程的效率和质量。...

    python之poplib模块下载并解析邮件.docx

    在这个例子中,我们看到如何使用`poplib`配合`email`模块来下载和解析电子邮件。下面我们将详细讨论这些知识点。 首先,`poplib`模块提供了与POP3服务器交互的功能。你可以通过`poplib.POP3`类建立连接,然后进行...

    python 标准库

    15. **email模块**:处理电子邮件消息,包括编码、解码和解析邮件头和正文。 在提供的文件`dice.py`中,可能涉及的是用Python模拟掷骰子的游戏,或者实现某种随机数相关的功能。由于没有具体内容,我们只能推测,但...

    Python库 | email_report_checker-0.0.1-py2.py3-none-any.whl

    Python的`email`模块是标准库的一部分,提供了一整套处理电子邮件消息的工具,包括解析、生成、编码和解码。`email_report_checker`可能基于这个模块进行了扩展,添加了更高级的功能,如自动验证报告是否符合预定的...

    Python内置模块及说明

    43. **email**: 处理电子邮件和MIME数据的包,支持邮件的创建、解析和发送。 44. **json**: JSON编码和解码器,用于数据交换。 45. **base64**: 提供Base16、Base32、Base64和Base85数据编码。 46. **binascii**:...

    Python3.7.2中文文档-标准库-Python文件格式

    11. **`email`** 和 **`email.mime`**:这是一个全面的电子邮件处理库,支持解析、生成和发送电子邮件,包括MIME附件。 12. **`datetime`**:提供了日期和时间操作,包括日期和时间的格式化、解析、比较和计算。 ...

    一个能发邮件的文本编辑器

    标签“Python email”表明这个编辑器使用了Python的电子邮件处理模块,如`email`和`smtplib`。`email`模块提供了一套完整的API,用于创建、解析和操作电子邮件消息,而`smtplib`则用于发送邮件。通过这两个模块,...

    email-4.0.2.tar.gz

    《Python邮件处理模块email的深度解析与应用》 在Python编程中,`email`模块是处理电子邮件消息的核心库,它提供了全面的工具来构建、解析和操作电子邮件消息。`email`模块是Python标准库的一部分,但随着时间的...

    The Python 3 Standard Library by Example.pdf

    `email`模块处理电子邮件的编码、解码和解析。 7. **并发和多线程**:`threading`模块提供了多线程支持,`concurrent.futures`模块则提供了一种更高级的并发执行接口。`queue`模块用于线程间的同步和通信。 8. **...

    python标准库PDF

    5. **互联网数据协议**:`xml.etree.ElementTree`处理XML数据,`email`和`smtp`处理电子邮件,`ftplib`实现了FTP协议,`poplib`和`imaplib`用于POP3和IMAP4邮件服务器的交互。 6. **数据结构**:`collections`模块...

    Python2 protobuf文件

    4. **编码和解码数据**:现在你可以导入生成的Python模块并在程序中使用protobuf。 ```python import person_pb2 # 创建一个Person实例 person = person_pb2.Person() person.name = 'John Doe' person.id = ...

    Python api 库函数学习

    Python标准库提供了处理电子邮件的功能,如: - **rfc822**: 提供了处理RFC822格式邮件头的功能。 - **mimetools**: 提供了MIME消息处理的功能。 - **mailbox**: 用于读写邮箱文件。 ##### 7.1 使用场景与案例分析...

    Python3_Web:基于《 Python网络编程》第三版的源代码加自己的一些注释解

    - smtplib和email模块:用于发送电子邮件,包括附件、HTML内容等。 - ftplib模块:实现FTP客户端功能,可以上传、下载文件。 通过Python3_Web项目,读者不仅可以学习到网络编程的基础知识,还能了解到Web服务开发...

    Python标准库实例

    16. **email**:处理电子邮件的模块,包括解析、构建和发送邮件。 17. **sqlite3**:轻量级数据库引擎,可直接在Python程序中使用SQL语句操作数据库。 18. **pdb**:Python的调试器,可以帮助定位和修复代码中的...

    《Python标准库》中文版

    quopri模块提供了quoted-printable编码和解码的功能,用于电子邮件等场景。 **4.14 uu模块** uu模块提供了uuencode和uudecode的功能,用于文件传输。 **4.15 binascii模块** binascii模块提供了多种二进制到ASCII...

Global site tag (gtag.js) - Google Analytics