gpt4 book ai didi

python+POP3实现批量下载邮件附件

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章python+POP3实现批量下载邮件附件由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

最近新开学,接到了给老板的本科课程当助教的工作,百十来号人一学期下来得有四五次作业发进邮箱里,需要我来统计打分,想想挨个点进去下载附件的过程就头大,于是萌生了写个脚本来统计作业的想法.

其实python里收发邮件都有很方便的包,合理使用就好,可以解决绝大多数的邮件收发任务。但是这个脚本写下来还是花了不少时间,其中最大的一部分时间是花在了python的编码问题上,python2和python3的编码预设有些许的不一样,在python3中又取消了unicode这个方法,这就导致很多在python2中写的例程都没法在3中运行.

经过修改以后下面的脚本可以从邮箱中获取指定日期范围内的邮件附件,并存如指定目录中.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import poplib
import email
import datetime
import time
import os
import xlrd
import xlwt
from email.parser import Parser
from email.header import decode_header
from email.utils import parseaddr
 
 
 
# 输入邮件地址, 口令和POP3服务器地址:
email = 'xxxxxxxx@qq.com'
password = 'xxxxxxxxxxx'
pop3_server = 'pop.qq.com'
 
 
 
def decode_str(s): #字符编码转换
   value, charset = decode_header(s)[ 0 ]
   if charset:
     value = value.decode(charset)
   return value
 
 
def get_att(msg):
   import email
   attachment_files = []
   
   for part in msg.walk():
     file_name = part.get_filename() #获取附件名称类型
     contType = part.get_content_type()
     
     if file_name: 
       h = email.header.Header(file_name)
       dh = email.header.decode_header(h) #对附件名称进行解码
       filename = dh[ 0 ][ 0 ]
       if dh[ 0 ][ 1 ]:
         filename = decode_str( str (filename,dh[ 0 ][ 1 ])) #将附件名称可读化
         print (filename)
         #filename = filename.encode("utf-8")
       data = part.get_payload(decode = True ) #下载附件
       att_file = open ( 'E:\\L\\zy\\307\\' + filename, ' wb') #在指定目录下创建文件,注意二进制文件需要用wb模式打开
       attachment_files.append(filename)
       att_file.write(data) #保存附件
       att_file.close()
   return attachment_files
 
     
       
# 连接到POP3服务器,有些邮箱服务器需要ssl加密,对于不需要加密的服务器可以使用poplib.POP3()
server = poplib.POP3_SSL(pop3_server)
server.set_debuglevel( 1 )
# 打印POP3服务器的欢迎文字:
print (server.getwelcome().decode( 'utf-8' ))
# 身份认证:
server.user(email)
server.pass_(password)
# 返回邮件数量和占用空间:
print ( 'Messages: %s. Size: %s' % server.stat())
# list()返回所有邮件的编号:
resp, mails, octets = server. list ()
# 可以查看返回的列表类似[b'1 82923', b'2 2184', ...]
print (mails)
index = len (mails)
 
 
 
for i in range (index, 0 , - 1 ):
   #倒序遍历邮件
   resp, lines, octets = server.retr(i)
   # lines存储了邮件的原始文本的每一行,
   #邮件的原始文本:
   msg_content = b '\r\n' .join(lines).decode( 'utf-8' )
   #解析邮件:
   msg = Parser().parsestr(msg_content)
   #获取邮件时间
   date1 = time.strptime(msg.get( "Date" )[ 0 : 24 ], '%a, %d %b %Y %H:%M:%S' ) #格式化收件时间
   date2 = time.strftime( "%Y%m%d" , date1) #邮件时间格式转换
   if (date2< '20180306' )|(date2> '20180314' ):
     
     continue
   f_list = get_att(msg) #获取附件
   
     
   
   #print_info(msg)
 
server.quit()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:https://blog.csdn.net/li_huifei/article/details/79529597 。

最后此篇关于python+POP3实现批量下载邮件附件的文章就讲到这里了,如果你想了解更多关于python+POP3实现批量下载邮件附件的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com