Python接收邮件并保存至MySQL
转自:http://www.360doc.com/content/14/0103/13/11789990_342303735.shtml
参考了一些网络上的资料,做了个简单程序,使用python接收邮件并保存到mysql中。
#-------------------------------------------------------------------------------
# Name: 接收邮件模块
# Purpose:
#
# Author: garfield
#
# Created: 15-02-2011
# Copyright: (c) garfield 2011
# Licence: <your licence>
#-------------------------------------------------------------------------------
#_*_encoding:utf-8_*_
####源代码用来接收邮件
import MySQLdb
import time
import poplib
import pickle
import email,string,sys,os
from email.Header import Header
from email.Header import decode_header
from time import strptime, strftime ISOTIMEFORMAT="%Y-%m-%d %X" #定义数据库常量
MySQL_Server="localhost"
MySQL_User="root"
MySQL_Password="****"
MySQL_Database="Python" #定义邮件服务器常量
POP3Sever='pop3.sina.com'
POP3User='mailuser'
POP3Password='*****' CurMailID=-1 #取信息编码
def get_charset(message, default="ascii"):
#Get the message charset
return message.get_charset()
return default def SaveMail(Sender,Receiver,Subject,SendDate,ReceiveDate,TextContent,HTMLContent,OriginalMailinfo):
#save mail info to mysql
Sender=MySQLdb.escape_string(Sender)
Receiver=MySQLdb.escape_string(Receiver)
Subject=MySQLdb.escape_string(Subject)
TextContent=MySQLdb.escape_string(TextContent)
HTMLContent=MySQLdb.escape_string(HTMLContent)
OriginalMailinfo=MySQLdb.escape_string(OriginalMailinfo)
conn = MySQLdb.connect(MySQL_Server,MySQL_User,MySQL_Password,MySQL_Database,port=3306,connect_timeout=10,compress=True,charset='utf8',use_unicode=True)
cursor=conn.cursor()
vsql="insert into mail(Sender,Receiver,Subject,SendDate,ReceiveDate,TextContent,HTMLContent,OriginalMailinfo) values('%s','%s','%s','%s','%s','%s','%s','%s')" % (Sender,Receiver,Subject,SendDate,ReceiveDate,TextContent,HTMLContent,OriginalMailinfo) ;
vsql = vsql.encode('utf8')
cursor.execute(vsql)#一条SQL语句 vsql = "SELECT max(id) from mail"
cursor.execute(vsql)
CurMailID=cursor.fetchone()[0] conn.commit()
cursor.close()
conn.close() def SaveMailAtta(vMailID,vFileName,Content,IsInline):
vFileName=MySQLdb.escape_string(vFileName)
Content=MySQLdb.escape_string(Content)
conn = MySQLdb.connect(MySQL_Server,MySQL_User,MySQL_Password,MySQL_Database,port=3306,connect_timeout=10,compress=True,charset='utf8',use_unicode=True)
cursor=conn.cursor()
vsql="insert into mailatta(mailid,filename,content,isinline) values('%s','%s','%s','%s')" % (vMailID,vFileName,Content,IsInline) ;
vsql = vsql.encode('utf8')
cursor.execute(vsql)#一条SQL语句 conn.commit()
cursor.close()
conn.close() #解析邮件
def ParseMail(mail):
textplain=''
texthtml=''
atta={}
if mail.is_multipart():
for par in mail.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) # 解码出附件数据,然后存储到文件中
atta[fname]=data
"""
try:
f = open(fname, 'wb') #注意一定要用wb来打开文件,因为附件一般都是二进制文件
except:
print '附件名有非法字符,自动换一个'
f = open('aaaa', 'wb')
f.write(data)
f.close()
"""
else:
#不是附件,是文本内容
content_type=par.get_content_type()
charset = get_charset(par)
if content_type in ['text/plain']:
if charset==None:
textplain=par.get_payload(decode=True)
else:
textplain=par.get_payload(decode=True).decode(charset)
if content_type in ['text/html']:
if charset==None:
texthtml=par.get_payload(decode=True)
else:
texthtml=par.get_payload(decode=True).decode(charset)
else:
type=mail.get_content_charset()
if type==None:
textplain=mail.get_payload()
else:
try:
textplain=unicode(mail.get_payload('base64'),type)
except UnicodeDecodeError:
textplain='Error' return (textplain,texthtml,atta) def main():
t=time.strftime( ISOTIMEFORMAT, time.localtime()) popClient=poplib.POP3(POP3Sever)
popClient.set_debuglevel(1)
popClient.user(POP3User)
popClient.pass_(POP3Password) numMsgs,mboxSize=popClient.stat() for id in range (numMsgs):
hdr,message,octet=popClient.retr(id+1)
mail=email.message_from_string(string.join(message, '\n'))
subject=mail.get("subject")
h = email.Header.Header(subject)
dh = email.Header.decode_header(h)
subject = dh[0][0] FromAddr=email.utils.parseaddr(mail['from'])[1]
ToAddr=email.utils.parseaddr(mail['To'])[1]
mdate=mail.get('date') #'Wed, 16 Feb 2011 14:34:44 +0800'
mdate=mdate[0:len(mdate)-6]
#:取邮件中的时间进行处理
md= mktime(strptime(mdate,"%a, %d %b %Y %H:%M:%S"))
MailDate=time.strftime(ISOTIMEFORMAT,time.localtime(md))
originalmailinfo=mail.as_string()
TextContent,HTMLContent,MailAtta=ParseMail(mail)
#保存邮件
SaveMail(FromAddr,ToAddr,subject,MailDate,MailDate,TextContent,HTMLContent,originalmailinfo)
#保存邮件附件
#for fk in MailAtta.keys():
# SaveMailAtta(CurMailID,fk,MailAtta[fk],False)
popClient.quit() if __name__=='__main__':
main() 但附件因为是二进制文件,所以保存到数据库中时需要序列化或进行其他处理,所以以上程序中的附件还不能这么简单地进行保存,需要进一步修改。 MySQL数据库脚本: --
-- 表的结构 `mail`
-- CREATE TABLE IF NOT EXISTS `mail` (
`ID` int(10) NOT NULL auto_increment,
`Sender` text,
`Receiver` text,
`SendDate` datetime default NULL,
`ReceiveDate` datetime default NULL,
`Subject` varchar(500) default NULL,
`TextContent` text,
`HTMLContent` text,
`OriginalMailInfo` text,
PRIMARY KEY (`ID`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=546 ; -- --
-- 表的结构 `mailatta`
-- CREATE TABLE IF NOT EXISTS `mailatta` (
`ID` int(11) NOT NULL auto_increment,
`MailID` int(11) NOT NULL,
`filename` varchar(200) NOT NULL,
`isinline` tinyint(1) NOT NULL,
`conent` blob NOT NULL,
PRIMARY KEY (`ID`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
Python接收邮件并保存至MySQL的更多相关文章
- python接收邮件
# -*- coding: utf-8 -*- import poplib import email from email.parser import Parser from email.header ...
- python 利用pop3接收邮件并保存附件
def SaveAttach():# login the pop3 server ,retrive the new mails ,and download the attachments dstdir ...
- 使用python发送和接收邮件
关于电子邮件 大学之前,基本不用邮箱,所以基本感觉不到它的存在,也不知道有什么用:然而大学之后,随着认识的人越来越多,知识越来越广泛,邮箱已然成为很重要的通讯工具,大学一些课程作业需要有邮箱发给老师, ...
- Python 用IMAP接收邮件
一.简介IMAP(Internet Message Access Protocol),这个协议与POP一样,也是从邮件服务器上下载邮件到本机,不过IMAP比POP的功能要更加强大些,IMAP除支持PO ...
- 转--python -- 收发邮件
官方 import smtplib from email.mime.text import MIMEText from email.header import Header # 发送邮箱服务器 smt ...
- outlook 2016 for windows 每次刷新发送接收邮件会弹出登陆界面
Q: outlook2016 for windows 每次刷新发送接收邮件会弹出登陆界面,office365 ProPlus 都是正常激活了,Word 和Excel都不存在此类问题 A: 排除用户的o ...
- Android pop3与imap方式接收邮件(javamail)
需要下载3个jar包:mail.jar/ activation.jar/ additionnal.jar 1.pop3 /** * 以pop3方式读取邮件,此方法不能读取邮件是否为已读,已 ...
- python SMTP邮件发送(转载)
Python SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式. py ...
- Python收发邮件
发送邮件使用SMTP协议,接受POP3或IMAP: 创建邮件内容email模块,发送邮件smtplib模块.发送邮件比较简单,只需先创建SMTP对象,登录服务器后根据发收邮箱地址发送即可: POP3接 ...
随机推荐
- 趣谈Java变量的可见性问题
了解过多线程的我们,对synchorized,sleep和valatile都比较了解,但是当这三个名词和“Java变量得可见性”的话题联系在一起不知道大家是否还可以保持大脑清晰??? 最近看到一个关于 ...
- 实用ExtJS教程100例-002:MessageBox的三种用法
在上一节中,我们用到了MessageBox,在本文中,我们将介绍一下ExtJS中常用的三种MessageBox. Ext.MessageBox.alert() 这个方法用来打开一个普通的对话框,对话框 ...
- c# action<> func<> 这2个委托怎么用和理解
其实很好理解的呢!~首先你需要明白,他们是委托的简写形式. 一.[action<>]指定那些只有输入参数,没有返回值的委托 1.1定义一个委托: 比如,我们原来写委托: public de ...
- [A类会议] 国内论文检索
https://www.cn-ki.net/ http://www.koovin.com
- nfd指令的详细说明
在eterm上执行NFD:SHAPEK/CA*OW指令,返回如下: LN CXR OW RT FBC/TC RBD MIN/MAX TRVDATE R 01 CA 450.00 U U 00D/00D ...
- BERT深度解析
这篇文章看起来很不错: https://blog.csdn.net/qq_39521554/article/details/83062188 仔细看看. 也可以看这个github,一样的文章: htt ...
- Libxml2函数及使用方法概述【转】
https://blog.csdn.net/chengwenyao18/article/details/7176082 一.关于XML: 在开始研究 Libxml2 库之前,先了解一下XML的相关基础 ...
- .NET开发过程中的全文索引使用技巧之Solr(转)
前言:相信许多人都听说过.net开发过程中基于Lucene.net实现的全文索引,而Solr是一个高性能,基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询 ...
- 浅谈提升C#正则表达式效率
摘要:说到C#的Regex,谈到最多的应该就是RegexOptions.Compiled这个东西,传说中在匹配速度方面,RegexOptions.Compiled是可以提升匹配速度的,但在启动速度上 ...
- Proxy 动态代理 InvocationHandler CGLIB MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...