从标签下载所有电子邮件为pdf格式(Gmail)

Python : download as pdf all emails from a label (gmail)(从标签下载所有电子邮件为pdf格式(Gmail))
本文介绍了从标签下载所有电子邮件为pdf格式(Gmail)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想从Gmail下载100多封电子邮件作为pdf。通过Gmail中的打印选项手动下载所有这些文件太长了。

此python脚本检索所选标签中的电子邮件。我怎样才能将这封电子邮件转换成pdf。

# source  = https://developers.google.com/gmail/api/quickstart/python?authuser=2

from __future__ import print_function
import pickle
import os.path
from googleapiclient.discovery import build
from google_auth_oauthlib.flow import InstalledAppFlow
from google.auth.transport.requests import Request



SCOPES = ['https://www.googleapis.com/auth/gmail.readonly']

def main():
    creds = None

    if os.path.exists('token.pickle'):
        with open('token.pickle', 'rb') as token:
            creds = pickle.load(token)
    # If there are no (valid) credentials available, let the user log in.
    if not creds or not creds.valid:
        if creds and creds.expired and creds.refresh_token:
            creds.refresh(Request())
        else:
            flow = InstalledAppFlow.from_client_secrets_file(
                'credentials.json', SCOPES)
            creds = flow.run_local_server()
        # Save the credentials for the next run
        with open('token.pickle', 'wb') as token:
            pickle.dump(creds, token)

    service = build('gmail', 'v1', credentials=creds)

    # Call the Gmail API 

    response= service.users().messages().list(userId="me", labelIds="Label_53", q=None, pageToken=None, maxResults=None, includeSpamTrash=None).execute()
    all_message_in_label = []
    if 'messages' in response:
        all_message_in_label.extend(response['messages'])

    while 'nextPageToken' in response:
      page_token = response['nextPageToken']
      response = service.users().messages().list(userId="me", labelIds="Label_53", q=None, pageToken=page_token, maxResults=None, includeSpamTrash=None).execute()
      all_message_in_label.extend(response['messages'])


    if not all_message_in_label:
        print('No email LM found.')
    else:
        # get message from Id listed in all_message_in_label
        for emails in all_message_in_label: 
            message= service.users().messages().get(userId="me", id=emails["id"], format="raw", metadataHeaders=None).execute()



if __name__ == '__main__':
    main()

推荐答案

我对您的问题做了一些挖掘,找到了一些可能有用的链接:

将您的邮件转换为.eml格式this链接。

.eml转换为.pdf这些链接:

eml2pdf是一个将eml文件转换为pdf文件的python GitHub项目,但我不确定它是否工作。您可以查看它是否正常工作。

eml-to-pdf是GitHub的另一个项目,看似较差,但仍在发挥作用。它是用Java脚本编写的。

并且有pyPdf可用于生成pdf文件。不过,您可能需要自己转换电子邮件并格式化它们。

有关消息对象格式的详细信息,请参阅Gmail API python文档get方法。

和here是一篇博客文章,它使用不同的方法实现了您想要的功能,但我不能完全确定它是否仍然有效。

我希望它能有所帮助。祝你好运。

这篇关于从标签下载所有电子邮件为pdf格式(Gmail)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)