python操作gmail

简介:


import  imaplib, re
 
class  pygmail( object ):
     def  __init__( self ):
         self .IMAP_SERVER = 'imap.gmail.com'
         self .IMAP_PORT = 993
         self .M =  None
         self .response =  None
         self .mailboxes =  []
 
     def  login( self , username, password):
         self .M =  imaplib.IMAP4_SSL( self .IMAP_SERVER, self .IMAP_PORT)
         rc, self .response =  self .M.login(username, password)
         return  rc
 
     def  get_mailboxes( self ):
         rc, self .response =  self .M. list ()
         for  item in  self .response:
             self .mailboxes.append(item.split()[ - 1 ])
         return  rc
 
     def  get_mail_count( self , folder = 'Inbox' ):
         rc, self .response =  self .M.select(folder)
         return  self .response[ 0 ]
 
     def  get_unread_count( self , folder = 'Inbox' ):
         rc, self .response =  self .M.status(folder, "(UNSEEN)" )
         unreadCount =  re.search( "UNSEEN (\d+)" , self .response[ 0 ]).group( 1 )
         return  unreadCount
 
     def  get_imap_quota( self ):
         quotaStr =  self .M.getquotaroot( "Inbox" )[ 1 ][ 1 ][ 0 ]
         r =  re. compile ( '\d+' ).findall(quotaStr)
         if  r = =  []:
             r.append( 0 )
             r.append( 0 )
         return  float (r[ 1 ]) / 1024 , float (r[ 0 ]) / 1024
 
     def  get_mails_from( self , uid, folder = 'Inbox' ):
         status, count =  self .M.select(folder, readonly = 1 )
         status, response =  self .M.search( None , 'FROM' , uid)
         email_ids =  [e_id for  e_id in  response[ 0 ].split()]
         return  email_ids
 
     def  get_mail_from_id( self , id ):
         status, response =  self .M.fetch( id , '(body[header.fields (subject)])' )
         return  response
 
     def  rename_mailbox( self , oldmailbox, newmailbox):
         rc, self .response =  self .M.rename(oldmailbox, newmailbox)
         return  rc
 
     def  create_mailbox( self , mailbox):
         rc, self .response =  self .M.create(mailbox)
         return  rc
 
     def  delete_mailbox( self , mailbox):
         rc, self .response =  self .M.delete(mailbox)
         return  rc
 
     def  logout( self ):
         self .M.logout()
 
if  __name__ = = "__main__" :
     demo = pygmail()
     demo.login( "renwenchao888@gmail.com" , "qqq191430791" )
     mailBoxex = demo.get_mailboxes()
     for  i in  demo.response:
         print  i
     demo.logout()
    

  


=============================================================================
本文转自被遗忘的博客园博客,原文链接:http://www.cnblogs.com/rollenholt/archive/2011/12/08/2280652.html,如需转载请自行联系原作者


相关文章
|
17天前
|
Python
如何使用Python的Pandas库进行数据透视图(melt/cast)操作?
Pandas的`melt()`和`pivot()`函数用于数据透视。基本步骤:导入pandas,创建DataFrame,然后使用这两个函数变换数据。示例代码:导入pandas,定义一个包含'Name'和'Age'列的DataFrame,使用`melt()`转为长格式,再用`pivot()`恢复为宽格式。
26 1
|
1月前
|
SQL 关系型数据库 MySQL
python操作mysql
python操作mysql
|
1月前
|
人工智能 机器人 C++
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
|
1月前
|
人工智能 机器人 Serverless
【Python】Pandas的一系列经典操作(非常实用)
【Python】Pandas的一系列经典操作(非常实用)
|
10天前
|
SQL 关系型数据库 MySQL
使用Python的pymysql库连接MySQL,执行CRUD操作
使用Python的pymysql库连接MySQL,执行CRUD操作:安装pymysql,然后连接(host='localhost',user='root',password='yourpassword',database='yourdatabase'),创建游标。查询数据示例:`SELECT * FROM yourtable`;插入数据:`INSERT INTO yourtable...`;更新数据:`UPDATE yourtable SET...`;删除数据:`DELETE FROM yourtable WHERE...`。
25 0
|
11天前
|
分布式计算 DataWorks 关系型数据库
MaxCompute产品使用合集之我需要在MaxCompute客户端添加Python第三方包,我该怎么操作
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
11天前
|
SQL 关系型数据库 MySQL
Python操作mysql数据库
Python操作mysql数据库
|
13天前
|
弹性计算 Serverless 应用服务中间件
Serverless 应用引擎操作报错合集之阿里函数计算中出现'python app.py'的错误如何解决
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
24 3
|
14天前
|
存储 人工智能 索引
Python中的嵌套字典访问与操作详解
Python中的嵌套字典访问与操作详解
22 1
|
16天前
|
关系型数据库 MySQL 数据库
Python从入门到精通:2.3.1数据库操作与网络编程:使用Python连接和操作数据库
Python从入门到精通:2.3.1数据库操作与网络编程:使用Python连接和操作数据库