Python实现的查询mysql数据库并通过邮件发送信息功能


Posted in Python onMay 17, 2018

本文实例讲述了Python实现的查询mysql数据库并通过邮件发送信息功能。分享给大家供大家参考,具体如下:

这里使用Python查询mysql数据库,并通过邮件发送宕机信息。

Python代码如下:

#-*- coding: UTF-8 -*-
#!/usr/bin/env python
'''''
author:qlzhong
Created on 2015-6-29
征途宕机日志统计汇总
'''
import MySQLdb
import time
import datetime
import smtplib
from email.mime.text import MIMEText
mailto_list=["mail@mail.com"]
#mailto_list=["zhongqilong@ztgame.com"]
mail_host="smtp.qq.com" #设置服务器
mail_user=""  #用户名
mail_pass=""  #口令
mail_postfix="" #发件箱的后缀
def send_mail(to_list,sub,content):
  me="hello"+"<"+mail_user+"@"+mail_postfix+">"
  msg = MIMEText(content,_subtype='plain',_charset='utf-8')
  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
class MySQLHelper:
  #配置数据库信息并连接
  def __init__(self,host="****",user="****",password="****",port=3306,charset="utf8"):
    self.host=host
    self.user=user
    self.password=password
    self.port=port
    self.charset=charset
    try:
      self.conn=MySQLdb.connect(host=self.host,user=self.user,passwd=self.password,port=self.port)
      self.conn.set_character_set(self.charset)
      self.cur=self.conn.cursor()
      print("==================connect success====================")
    except MySQLdb.Error as e:
      print("Mysql Error %d: %s" % (e.args[0], e.args[1]))
  #取出需要统计的数据库名称
  def db_name(self):
    un_db_name = ['information_schema','cz','ecshop','edutone','gz','mysql','newparent','parent','performance_schema','test','xx','yyhd']
    name = []
    try:
      self.cur.execute('show databases')
      for row in self.cur.fetchall():
        for i in row:
          if i not in un_db_name:
            name.append(i)
      return name
    except MySQLdb.Error as e:
      print("Mysql Error %d: %s" % (e.args[0], e.args[1]))
  #指定查询的数据库名称
  def selectDb(self,db):
    try:
      self.conn.select_db(db)
    except MySQLdb.Error as e:
      print("Mysql Error %d: %s" % (e.args[0], e.args[1]))
  #使用该语句来直接查询昨天和今天的差异
  def monion_today_yesddiff(self, today, yestoday):
    try:
      strresult = ""
      strsql = 'SELECT address, charversion, sum(today) as today, sum(yesterday) as yesterday '
      strsql += 'FROM (SELECT address, "" as today, tmp as yesterday, charversion FROM ( SELECT count(*) As tmp, address, charversion From `' + yestoday
      strsql += '` WHERE charversion like \'1.0.0.3%\' GROUP BY address) As TEST WHERE tmp>=50 '
      strsql += ' union all '
      strsql += 'SELECT address, tmp as today, "" as yesterday, charversion FROM (SELECT count(*) As tmp, address, charversion From `'
      strsql += today
      strsql += '` WHERE charversion like \'1.0.0.3%\' GROUP BY address) As TEST WHERE tmp>=50 ) As Diff GROUP BY address, charversion'
      print(strsql + "\n")
      self.cur.execute(strsql)
      name_list = [tuple[0] for tuple in self.cur.description]
      strresult += str(name_list) + "\n"
      # for row in self.cur.fetchall():
      #   return row
      s = self.cur.fetchall()
      todaynum = 0
      yestodaynum = 0
      for col in s:
        strresult += str(col[0]) + " " + str(col[1]) + " " + str(col[2]) + " " + str(col[3]) + "\n"
        todaynum += int(col[2])
        yestodaynum += int(col[3])
      strresult += "今日宕机总数:" + str(todaynum) + "  昨日宕机总数:" + str(yestodaynum) + "  同昨日相比增加: " + str(todaynum - yestodaynum) + "\n"
      return strresult
    except MySQLdb.Error as e:
      print("Mysql Error:%s\n" %(e))
  def close(self):
    self.cur.close()
    self.conn.close()
  todayrang = 0;
  yestodayrang = 0;
  #按照范围查询
  def monion_rang_today_yesddiff(self, today, yestoday, num1, num2):
    try:
      strresult = ""
      strsql = 'SELECT sum(today) as today, sum(yesterday) as yesterday FROM (SELECT "" as today, tmp as yesterday FROM ( SELECT count(*) As tmp From `' + yestoday
      strsql += '` WHERE charversion like \'1.0.0.3%\' GROUP BY address) As TEST WHERE tmp<' + str(num2) + ' AND tmp>=' + str(num1) + ' union all '
      strsql += 'SELECT tmp as today, "" as yesterday FROM (SELECT count(*) As tmp From `' + today + '` WHERE charversion like \'1.0.0.3%\'  GROUP BY address) As TEST WHERE tmp<' + str(num2) + ' AND tmp>=' + str(num1) + ' ) As Diff'
      print(strsql + "\n")
      self.cur.execute(strsql)
      name_list = [tuple[0] for tuple in self.cur.description]
      #strresult += str(name_list) + "\n"
      # for row in self.cur.fetchall():
      #   return row
      s = self.cur.fetchall()
      todaynum = 0
      yestodaynum = 0
      for col in s:
        strresult += str(num1) + " <= tmp < " + str(num2) + "  " + str(col[0]) + " " + str(col[1]) + "\n"
        self.todayrang += int(col[0])
        self.yestodayrang += int(col[1])
      return strresult
    except MySQLdb.Error as e:
      print("Mysql Error:%s\n" %(e))
  def close(self):
    self.cur.close()
    self.conn.close()
  #宕机数地址50以下最多的版本
  def monion_rang_today_diff(self, today, num):
    try:
      strresult = ""
      strsql = 'SELECT charversion, sum(today) as today FROM (SELECT tmp as today, "" as yesterday, charversion FROM (SELECT count(*) As tmp, charversion From `' + today
      strsql += '` WHERE charversion like \'1.0.0.3%\'  GROUP BY address) As TEST WHERE tmp< ' + str(num) + ') As Diff GROUP BY charversion'
      print(strsql + "\n")
      self.cur.execute(strsql)
      name_list = [tuple[0] for tuple in self.cur.description]
      #strresult += str(name_list) + "\n"
      # for row in self.cur.fetchall():
      #   return row
      s = self.cur.fetchall()
      for col in s:
        strresult += str(col[0]) + " " + str(col[1]) + "\n"
      return strresult
    except MySQLdb.Error as e:
      print("Mysql Error:%s\n" %(e))
  def close(self):
    self.cur.close()
    self.conn.close()
if __name__ == '__main__':
  textbody=""
  textbody = textbody + "征途宕机日志查询汇总" + "\n"
  #时间
  timenow = datetime.datetime.now()
  textbody = textbody + "时间:" + timenow.strftime('%Y-%m-%d %H:%M:%S') + "\n"
  #连接
  ipadress="192.168.100.38"
  port=3306
  dbHelper = MySQLHelper(ipadress, "gameerror", "errorpasswd", port)
  textbody = textbody + "服务器地址:" + ipadress + ":" + str(port) + "\n"
  dbHelper.selectDb("GAMEERROR")
  #操作
  dbname = dbHelper.db_name()
  textbody = textbody + "数据库:" + str(dbname[0]) + "\n"
  time1 = timenow + datetime.timedelta(days = -1)
  time2 = timenow + datetime.timedelta(days = -2)
  strtime1 = time1.strftime('%Y%m%d')
  tabletoday = "ErrorDump" + strtime1
  strtime2 = time2.strftime('%Y%m%d')
  tableyestoday = "ErrorDump" + strtime2
  textbody = textbody + "table name: today: " + tabletoday + "  yestoday: " + tableyestoday + "\n"
  textbody = textbody + "\n昨天和今天的差异 宕机地址 版本号 今天宕机次数 昨天宕机次数" + "\n"
  textbody = textbody + str(dbHelper.monion_today_yesddiff(tabletoday, tableyestoday)) + "\n"
  textbody = textbody + "50以下地址(tmp代表某个宕机地址的个数) 今天 昨天:" + "\n"
  textbody = textbody + str(dbHelper.monion_rang_today_yesddiff(tabletoday, tableyestoday, 30, 50))
  textbody = textbody + str(dbHelper.monion_rang_today_yesddiff(tabletoday, tableyestoday, 10, 30))
  textbody = textbody + str(dbHelper.monion_rang_today_yesddiff(tabletoday, tableyestoday, 0, 10))
  textbody = textbody + "50以上地址总和" + "  今天: " + str(dbHelper.todayrang) + "  昨天: " + str(dbHelper.yestodayrang) + "  今天比昨天增加: " + str(dbHelper.todayrang - dbHelper.yestodayrang) + "\n"
  num=50
  textbody = textbody + "\n宕机数地址" + str(num) + "以下最多的版本 版本号 次数" + "\n"
  textbody = textbody + str(dbHelper.monion_rang_today_diff(tabletoday, num))
  file_object = open('ztdumptip.txt')
  try:
    all_the_text = file_object.read()
  finally:
    file_object.close()
  textbody += all_the_text
  print(textbody)
  if send_mail(mailto_list,"征途客户端宕机日志统计",textbody):
    print "发送成功"
  else:
    print "发送失败"
  dbHelper.close()

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python字符串处理实现单词反转
Jun 14 Python
Python实现解析Bit Torrent种子文件内容的方法
Aug 29 Python
基于Django与ajax之间的json传输方法
May 29 Python
Python基于多线程实现抓取数据存入数据库的方法
Jun 22 Python
pandas通过索引进行排序的示例
Nov 16 Python
django框架基于模板 生成 excel(xls) 文件操作示例
Jun 19 Python
在python中,使用scatter绘制散点图的实例
Jul 03 Python
详解如何在cmd命令窗口中搭建简单的python开发环境
Aug 29 Python
python常用数据重复项处理方法
Nov 22 Python
python之MSE、MAE、RMSE的使用
Feb 24 Python
Python实现常见的几种加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)
May 09 Python
python+django+selenium搭建简易自动化测试
Aug 19 Python
Python实现读取txt文件并转换为excel的方法示例
May 17 #Python
cmd运行python文件时对结果进行保存的方法
May 16 #Python
Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例
May 16 #Python
Python使用Dijkstra算法实现求解图中最短路径距离问题详解
May 16 #Python
Python基于Floyd算法求解最短路径距离问题实例详解
May 16 #Python
Python使用selenium实现网页用户名 密码 验证码自动登录功能
May 16 #Python
Selenium 模拟浏览器动态加载页面的实现方法
May 16 #Python
You might like
QQ登录 PHP OAuth示例代码
2011/07/20 PHP
PHP中spl_autoload_register函数的用法总结
2013/11/07 PHP
PHP用身份证号获取星座和生肖的方法
2013/11/07 PHP
详解PHP的Yii框架中自带的前端资源包的使用
2016/03/31 PHP
PHP钩子与简单分发方式实例分析
2017/09/04 PHP
php-msf源码详解
2017/12/25 PHP
网页和浏览器兼容性问题汇总(draft1)
2009/06/01 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
2013/08/22 Javascript
js语法学习之判断一个对象是否为数组
2014/05/13 Javascript
jquery中使用循环下拉菜单示例代码
2014/09/24 Javascript
javascript判断css3动画结束 css3动画结束的回调函数
2015/03/10 Javascript
nodejs中实现阻塞实例
2015/03/24 NodeJs
jQuery实现有动画淡出效果的二级折叠菜单代码
2015/10/17 Javascript
vue.js将unix时间戳转换为自定义时间格式
2017/01/03 Javascript
jQuery UI Draggable + Sortable 结合使用(实例讲解)
2017/09/07 jQuery
express.js中间件说明详解
2019/03/19 Javascript
React Hooks 实现和由来以及解决的问题详解
2020/01/17 Javascript
在 Vue 中使用 JSX 及使用它的原因浅析
2020/02/10 Javascript
vue axios封装httpjs,接口公用配置拦截操作
2020/08/11 Javascript
JS遍历树层级关系实现原理解析
2020/08/31 Javascript
vue中父子组件的参数传递和应用示例
2021/01/04 Vue.js
python中根据字符串调用函数的实现方法
2016/06/12 Python
python 统计代码行数简单实例
2017/05/04 Python
Python批量查询域名是否被注册过
2017/06/21 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
matplotlib 对坐标的控制,加图例注释的操作
2020/04/17 Python
使用SQLAlchemy操作数据库表过程解析
2020/06/10 Python
Woolworth官网:澳洲第一大超市
2017/06/25 全球购物
美国最大的无人机经销商:DroneNerds
2018/03/20 全球购物
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/01/13 面试题
最新销售员个人自荐信
2013/09/21 职场文书
会计学个人自荐信模板
2013/12/13 职场文书
研究生简历自我评价范文
2014/09/13 职场文书
基层党组织整改方案
2014/10/25 职场文书
少先队入队仪式主持词
2015/07/04 职场文书
python爬虫框架feapde的使用简介
2021/04/20 Python