通过python查找数据库内容自动发送excel邮件

入职半年了开始写博客,纪念一下,顺便分享自己的经验

入职第一周接到的项目是帮助运维组实现从数据库查找符合匹配的数据,并通过excel发送给运维组人员这样的一个脚本

因为公司这个项目是用python2.7,所以需要修改的地方自己处理一下,基本上复制粘贴就可以使用了

# -*- coding: utf-8 -*
# @File    : sendmail.py
import json
import pymysql
import smtplib
import datetime
import pandas as pd
from email.mime.text import MIMEText
from email.header import Header
from email.mime.multipart import MIMEMultipart

# 查询数据
def query(sql):
    # 初始化mysql连接,不同的数据库替换参数
    db= pymysql.connect(host="localhost",user="root",password="123456",db="python_do",port=3306,autocommit=True)
    cursor = db.cursor()
    sql = sql
    try:
        cursor.execute(sql)
        return cursor.fetchall()
    except:
        print("Error: unable to fetch data")

    db.close()

# 导出到excel
def Export():
#这一段是处理国区时间+8,可以自己在sql里面进行处理(不会的自己找sql大神),也可以直接复制粘贴
    #now = datetime.datetime.now() - datetime.timedelta(hours=8)
    #yestoday = now - datetime.timedelta(days=1)
    #now_string = now.strftime('%Y-%m-%d %H:%M:%S')
    #yestoday_string = yestoday.strftime('%Y-%m-%d %H:%M:%S')
#自己修改excel里面需要的标题
    headers = [u'序号',u'标题']
    #for i in data or []:
    data = query(‘你自己的sql语句’)
    #datalist = []
        #tmp = list(i)
        #tmp[3] += datetime.timedelta(hours=8)
        #tmp[4] += datetime.timedelta(hours=8)
        #datalist.append(tmp)
    genexcel = tablib.Dataset(*data, headers=headers)
    datajson =  json.loads(genexcel.json)
    xlsx = xlwt.Workbook(encoding='utf-8')
    sheet = xlsx.add_sheet('sheet1', True)
    for count, i in enumerate(headers):
        sheet.write(0, count, i)
    
    for count, i in enumerate(datajson):
        for c, j in enumerate(headers):
            sheet.write(count + 1, c, i[j])
    xlsx.save(‘excle.xls')    

# 发送邮件
def SendMail():

    _user = '123456@163.com'
    _pwd = "123456"
    _to = ["1234456@qq.com","12341234@139.com""]
    msg = MIMEMultipart()
    body = MIMEText("每日报障", 'HTML', 'utf-8')
    msg['Subject'] = Header("每日报障", 'utf-8')
    msg['From'] = _user
    msg['To'] =','.join(_to)

    msg.attach(body)

    # 添加附件
    att = MIMEText(open("/home/day/excel.xls", "rb").read(),"base64", "utf-8")  # 打开附件地址

    att["Content-Type"] = "application/octet-stream"
    att["Content-Disposition"] = 'attachment; filename="day.xls"'
    msg.attach(att)

    # 发送邮件
    s = smtplib.SMTP_SSL("smtp.163.com")
    s.login(_user, _pwd)
    s.sendmail(_user, msg['to'].split(','), msg.as_string())

    s.quit()
    print("邮件发送成功")


if __name__ == '__main__':
    Export()
    SendMail()

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值