python获取邮箱地址_使用python获取邮箱邮件

首先我们要在邮箱的设置中开通那个POP3

然后我们要导入这些包

import poplib

from datetime import datetime

import jieba

import re

from email.parser import Parser

from email.header import decode_header

from email.utils import parseaddr

from lxml import etree

然后进行链接

name_list = []

email = 'xxx@xx.com'

password = 'xxxxxx'

pop3_server = 'imap.exmail.qq.com'

# 连接到POP3服务器:

server = poplib.POP3(pop3_server)

# 可以打开或关闭调试信息:

server.set_debuglevel(1)

# 可选:打印POP3服务器的欢迎文字:

print(server.getwelcome().decode('utf-8'))

# 身份认证:

server.user(email)

server.pass_(password)

# stat()返回邮件数量和占用空间:

print('Messages: %s. Size: %s' % server.stat())

# list()返回所有邮件的编号:

resp, mails, octets = server.list()

# 可以查看返回的列表类似[b'1 82923', b'2 2184', ...]

print(mails)

# 获取最新一封邮件, 注意索引号从1开始:

index = len(mails)

print(index,'2222')

resp, lines, octets = server.retr(284)

# lines存储了邮件的原始文本的每一行,

# 可以获得整个邮件的原始文本:

msg_content = b'\r\n'.join(lines).decode('utf-8')

# 稍后解析出邮件:

msg = Parser().parsestr(msg_content)

# print(msg)

messageObject = Parser().parsestr(msg_content)

msgDate = messageObject["date"]

print(678,msgDate)

# 可以根据邮件索引号直接从服务器删除邮件:

# server.dele(index)

# 关闭连接:

这里的index是全部的邮件数量,server.retr(284),从最新的开始,retr里面传你要读取的第几个,

try:

GMT_FORMAT = '%a, %d %b %Y %H:%M:%S +0800 (CST)'

new_date = datetime.strptime(msgDate, GMT_FORMAT)

except:

GMT_FORMAT = '%a, %d %b %Y %H:%M:%S +0800'

new_date = datetime.strptime(msgDate, GMT_FORMAT)

name_list.append(str(new_date))

print(datetime.strptime(msgDate, GMT_FORMAT))

直接读取出来的时间是Tue, 17 Sep 2019 16:21:25 +0800(CST) 这种形式,这里是转为为2019-09-17 16:21:25这种亚子。哈哈

继续

def print_info(msg, indent=0):

if indent == 0:

for header in ['From', 'To', 'Subject']:

value = msg.get(header, '')

if value:

if header == 'Subject':

value = decode_str(value)

else:

hdr, addr = parseaddr(value)

name = decode_str(hdr)

value = u'%s ' % (name, addr)

print('7777',name)

print('%s%s: %s' % (' ' * indent, header, value))

if (msg.is_multipart()):

parts = msg.get_payload()

for n, part in enumerate(parts):

print('%spart %s' % (' ' * indent, n))

print('%s--------------------' % (' ' * indent))

print_info(part, indent + 1)

else:

content_type = msg.get_content_type()

if content_type == 'text/plain' or content_type == 'text/html':

content = msg.get_payload(decode=True)

charset = guess_charset(msg)

if charset:

content = content.decode(charset)

print('%sText: %s' % (' ' * indent, content + '...'))

else:

print('%sAttachment: %s' % (' ' * indent, content_type))

这里就是读取邮件内容了

继续还有两个函数

def decode_str(s):

value, charset = decode_header(s)[0]

if charset:

value = value.decode(charset)

return value

def guess_charset(msg):

charset = msg.get_charset()

if charset is None:

content_type = msg.get('Content-Type', '').lower()

pos = content_type.find('charset=')

if pos >= 0:

charset = content_type[pos + 8:].strip()

return charset

print_info(msg = msg)

print(name_list)

server.quit()

就这样了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值