码迷,mamicode.com
首页 > 数据库 > 详细

python读取postgresql数据库并发送相关提醒邮件

时间:2014-10-30 02:02:55      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:smtp   email   postgresql   python   

代码如下:

#!/usr/bin/env python

import smtplib

from email.mime.text import MIMEText

import psycopg2

import datetime


mail_host= "smtp.XXX.com" 
mail_user= "XXX"   
mail_pass=  "XXX" 
mail_postfix="XXX.com"


def send_mail(to_list,sub,content):  
    me="Remind Email"+"<"+mail_user+"@"+mail_postfix+">"  
    msg = MIMEText(content,_subtype=‘plain‘,_charset=‘gb2312‘)  
    msg[‘Subject‘] = sub  
    msg[‘From‘] = me  
    msg[‘To‘] = ";".join(to_list)  
    try:  
        server = smtplib.SMTP()  
        server.CONNECT(mail_host)  
        server.login(mail_user,mail_pass)  
        server.sendmail(me, to_list, msg.as_string())  
        server.close()  
        return True  
    except Exception, e:  
        print str(e)  
        return False  

        
        
## 取本地时间与数据库项目时间作比较 ##
today=strftime(‘%Y-%m-%d‘,localtime())
today_date=datetime.datetime(today,‘%Y-%m-%d‘)
        
## 与postgresql数据库链接 ##        
pgdb_conn = psycopg2.CONNECT(database = ‘test‘,user = ‘username‘, password = ‘123456‘, host = ‘1.1.1.1‘)
pg_cursor = pgdb_conn.cursor()
sql_desc = "select * from tbl_product3"
pg_cursor.execute(sql_desc)
for row in pg_cursor:  
        date=row[0]
        to_list=row[1]
        sub=row[2]
        content=row[3]
        Other_date=datetime.datetime(date,‘%Y-%m-%d‘)
        delta=Other_date-today_date
        if delta.days == 1:
            send_mail(to_list,sub,content)
                  
pg_cursor.close()  
pgdb_conn.close()

本文出自 “蓝鳍豚” 博客,请务必保留此出处http://likunheng.blog.51cto.com/9527645/1569445

python读取postgresql数据库并发送相关提醒邮件

标签:smtp   email   postgresql   python   

原文地址:http://likunheng.blog.51cto.com/9527645/1569445

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!