成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何用Python實現電子郵件的自動化

開發 后端 自動化
在本文中,我們將概述如何編寫一個Python腳本,該腳本可以下載一組特定的公共數據,然后將其上傳到電子郵件中,并將其發送給任何需要的人。

前言

用Python自動化日常任務很容易。通過api和庫的結合,您可以輕松地設置系統來抓取網站、發送電子郵件、管理數據和分析。

在本文中,我們將概述如何編寫一個Python腳本,該腳本可以下載一組特定的公共數據,然后將其上傳到電子郵件中,并將其發送給任何需要的人。

這將使您熟悉使用Python請求庫和Gmail API。因此,如果您希望將來使用Python自動處理電子郵件,這是一個很好的學習起點。

用Python下載文件

對于第一步,我們將需要使用HTTP請求實際下載數據文件。

在本例中,我們將要下載的文件甚至在下面的鏈接中有一個簡單的端點。因此,您不需要使用Selenium這樣的庫來嘗試單擊下載按鈕。通常,如果有一個URL,那么使用鏈接下載就非常容易。

https://data.medicaid.gov/api/views/u72p-j37s/rows.json?accessType=DOWNLOAD

這個文件提供關于醫療補助和個人登記的信息。這對醫療保健提供者來說是有價值的,他們可以將其與內部數據聯系起來,幫助更好地了解他們的市場。

為了下載它,我們將使用函數requests.get()。這將允許我們使用HTTP請求將數據拉到我們指定的URL。

例如,你可以看看下面的腳本:

  1. # Part 1: Fetch the data.​ 
  2.  
  3. # Get the webpage, store it in a Response object and assign the text 
  4. # About: https://requests.readthedocs.io/en/master/api/#requests.Response​ 
  5.  
  6. # This URL contains the .csv download of 
  7. 'https://catalog.data.gov/dataset/' \ 
  8. #  'share-of-medicaid-enrollees-in-managed-care' 
  9. # used to send to the destination e-mail. 
  10.  
  11. csvFileURL = 'https://data.medicaid.gov/api/' \  'views/u72p-j37s/rows
  12. csv?accessType=DOWNLOAD'csvFileRequest = requests.get(csvFileURL)csvFile = csvFileRequest.content 

它短小精悍,并將返回CSV作為您現在設置為變量的請求的一部分。我們稍后在創建電子郵件時將使用這個。但是接下來,我們需要設置Gmail API的憑據。

設置您的Gmail API

谷歌使您非常容易地設置api。您可以轉到谷歌API控制臺。從這里,您可以選擇ENABLE API和服務,然后搜索Gmail API。

API控制臺如下圖所示。

 

如何用Python實現電子郵件的自動化

你可以輸入Gmail,它應該是唯一出現的。

 

如何用Python實現電子郵件的自動化

然后您可以選擇Gmail API,它旁邊會有一個ENABLE按鈕。

 

如何用Python實現電子郵件的自動化

一旦您在Gmail API上單擊ENABLE,您就可以下載您的憑證或者使用API密鑰和密鑰。

我們的代碼將使用JSON下載,但如果您愿意,可以將其轉換為pickle。

 

如何用Python實現電子郵件的自動化

有了這些設置,我們現在可以開始建立你的功能設置,然后自動發送你的電子郵件。

使用Gmail API 發送郵件

現在我們已經找到了一種獲取數據的方法,我們需要弄清楚如何發送電子郵件。

為了做到這一點,我們將使用電子郵件庫。這個庫可以讓我們設置電子郵件的各個部分:發件人、收件人、主題等。

我們在電子郵件中使用MIMEBase類來實現這一點,這使得設置正確的數據點變得很容易,并且為將來使用的Gmail API提供了一個簡單的類。

使用MIMEBase類真的很簡單,因為你可以創建一個新的類,然后引用很多需要的組件,比如:

  1. message[‘from’] = test@gmail.com 

您可以看到我們在下面設置這些參數的整個函數。

  1. Function required for Part 2: Send e-mail with Google API. 
  2. # a) Create the message 
  3.  
  4. def create_message(sender, to, subject, csv):   
  5. #message = MIMEMultipart()   
  6.     message = MIMEMultipart() 
  7.   message['from'] = sender 
  8.   message['to'] = to   
  9.   message['subject'] = subject 
  10.  
  11. # Send the time it was updated as the body of the e-mail   
  12. dt_object = datetime.utcnow() - timedelta(hours = 7)   
  13. msg = MIMEText('Hi! Your file was updated.' \    '\nTime of update: ' + dt_object.strftime('%m/%d/%Y, %I:%M:%S %p') \    + ' (Los Angeles Time)')​   
  14. message.attach(msg) 
  15.  
  16. # Attach the .csv file   
  17. record = MIMEBase('application''octet-stream')   
  18. # print(csv)   
  19. record.set_payload(csv)   
  20. encoders.encode_base64(record)   
  21. record.add_header('Content-Disposition''attachment', filename='medicare.csv')   
  22. message.attach(record) 
  23.  
  24. Return the message   
  25. raw = base64.urlsafe_b64encode(message.as_bytes())   
  26. raw = raw.decode()   
  27. return {'raw': raw} 

您將注意到在最后,我們使用了函數urlsafe_b64encode。這將把消息設置為字節。這將用于輕松地將電子郵件數據傳輸到Gmail API。所以它很容易傳遞。

現在是時候發送你的第一封自動郵件了。​現在您已經設置了Gmail API憑據,我們可以發送第一封電子郵件了。我們將使用使用Gmail API和憑據設置的服務變量。這如下面的函數send_message所示。

  1. #b) Send the message 
  2.  
  3. def send_message(service, user_id, message):   
  4.     try:    message = service.users().messages(). \    
  5.     send(userId=user_id, body=message).execute()     
  6.    print('Message Id: %s' % message['id'])     
  7.    return message   
  8.  except Exception as e:     
  9.   print('An error occurred: %s' % e)     
  10.   return None 

從這里開始,我們需要做的就是傳遞消息并執行。至此,我們已經發送了第一封電子郵件。

責任編輯:未麗燕 來源: 今日頭條
相關推薦

2018-08-24 08:10:10

編程語言Python電子郵件

2019-08-08 14:55:19

電子郵件微軟信頭

2019-06-26 18:30:30

Linux命令行電子郵件

2018-08-31 09:55:38

Ansible網絡自動化

2020-01-06 09:00:34

容器CRD安全

2010-09-17 14:11:18

2018-09-05 14:45:10

Python自動化機器學習

2023-03-09 14:02:00

Inkscape圖形創作

2021-06-16 10:56:32

電子郵件電子郵件攻擊BEC

2011-10-31 09:35:50

2021-06-28 21:21:54

電子郵件郵件安全惡意軟件

2011-08-01 11:11:55

2010-10-21 13:54:20

2022-04-29 15:55:51

安全電子郵件病毒

2010-12-27 16:22:27

郵件地址

2011-12-15 10:45:33

2009-10-14 10:06:03

電子郵件安全關聯 網絡安全

2009-05-21 10:07:43

谷歌電子郵件自動翻譯

2010-06-10 14:10:58

安全電子郵件協議

2011-08-01 12:43:03

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人免费网站 | 青青草在线视频免费观看 | 成人网在线观看 | 日韩在线一区二区三区 | 成人在线观看免费 | 亚洲人成一区二区三区性色 | 欧美久久久久 | 成人h视频| 亚洲成人久久久 | 亚洲视频二区 | 国产精品高潮呻吟久久aⅴ码 | 欧美日一区二区 | 亚洲国产成人在线 | 国产亚洲成av人片在线观看桃 | 欧美日韩精品影院 | 亚洲福利免费 | 亚洲91视频 | a级黄色网 | 黄片毛片在线观看 | 欧美精品91 | 高清亚洲| 四虎最新地址 | 久久神马 | 成人三级视频 | 老司机久久 | 国产高清精品在线 | 中文字幕国产高清 | 亚洲九色 | 亚洲视频免费在线观看 | 中文字幕一区二区三区四区五区 | 亚洲在线一区二区三区 | 麻豆久久久 | 97精品国产97久久久久久免费 | 99re国产精品 | 中文字幕在线网 | 久久综合狠狠综合久久综合88 | 免费久久精品视频 | 成人欧美一区二区三区在线观看 | 五月综合激情婷婷 | 56pao在线| 婷婷色在线 |