设为首页 收藏本站
查看: 579|回复: 0

[经验分享] python查数据库发邮件

[复制链接]

尚未签到

发表于 2017-5-3 07:33:06 | 显示全部楼层 |阅读模式
  有时候需要将数据库中的统计信息统计好之后,直接每天定时发邮件。
  可用python脚本写好逻辑后,使用crontab每天定时执行

# -*- coding: UTF-8 -*-
import MySQLdb
import smtplib
from email.MIMEMultipart import MIMEMultipart
from email.MIMEText import MIMEText
def queryDBdata():   
#连数据库
conn = MySQLdb.connect(host='****', user='***', passwd='****', db='***', port=3307, charset='utf8')
querySQL="select sum(num),date from (SELECT count(e.order_num) num, date_format(r.order_date,'%Y-%m-%d') date from orders_extension e INNER JOIN commission_order r ON e.order_num=r.order_no where e.ex_cookie like '%bd%' and e.biz_type='COMMISSION' and date_format(r.order_date,'%Y-%m')=date_format(NOW(),'%Y-%m') group by date_format(r.order_date,'%Y-%m-%d')  union ALL  SELECT count(e.order_num) num, date_format(r.order_date,'%Y-%m-%d') date from orders_extension e INNER JOIN order_info  r ON e.order_num=r.order_num where e.ex_cookie like '%bd%' and e.biz_type='PPB' and date_format(r.order_date,'%Y-%m')=date_format(NOW(),'%Y-%m')  group by date_format(r.order_date,'%Y-%m-%d') ) a group by date"
cur = conn.cursor()
cur.execute("set names 'utf8'")
cur.execute(querySQL)
#获取数据
data="每天晚上九点自动发统计邮件\n\n"+"|    总订单数        |        日期                 |"+"\n"
results = cur.fetchall()
for r in results:
data=data+"|    "+str(r[0])+"    "+"|    "+str(r[1])+"    |\n"
return data

def send_mail(content):
try:
mailToList=['yebing.li@163.com',"erte@163.com"]
sender='yebing.li@163.com'
mailto=",".join(mailToList)
msg = MIMEMultipart()
msg['Subject'] = "本月****来源的订单"
msg['to'] = mailto
msg['From'] = sender
body = MIMEText(content)
msg.attach(body)
smtp = smtplib.SMTP('mail.163.com')
smtp.sendmail(sender,mailToList,msg.as_string())
smtp.quit()
except smtplib.SMTPException, e:
print "error...%d: %s" % (e.args[0], e.args[1])

if __name__=="__main__":
content=queryDBdata()
send_mail(content)
  其中crontab  -e 编辑表达式

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-372269-1-1.html 上篇帖子: python入门四:序列和字典 下篇帖子: Python对数组的基本操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表