qq自动发消息脚本 如何用Python来实现报表的自动发送
数据分析师小王每天都要被各种各样的数据数据报表搞得焦头烂额,比如老板的,运营的、产品的等等。而且大部分报表都是重复性的工作。这篇文章就是帮助大家如何用Python来实现报表的自动发送,解放你的劳动力,可以让你有时间去做更有意思的事情。
要点:
·pymysql一个可以连接MySQL实例并且实现增删改查功能的库
·datetimePython标准库中自带的关于时间的库
·openpyxl一个可以读写07版以后的Excel文档的库
·smtplibSMTP即简单邮件传输协议
·email一个用来处理邮件消息的库
01.
准备工作,导入相应的库
数据分析师日常大部分工作需要熟练掌握SQL和excel打交道,而且很多数据都带日期。所以我们需要导入下面这些模块:
pymysql,openxl,datatime,当然还有自动发邮件的email和smtplib模块。
# encoding=utf-8
import pymysql as pms
import openpyxl
import datetime
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.header import Header
import smtplib(代码可以左右滑动)
02.
连接SQL
现在主流的数据库有两大类,SQL和NoSQL,虽然Mongodb非常灵活和简单,但是大部分公司的数据库还是用Mysql比较多的!所以我们需要掌握一些基本的python操作数据库的知识!
1).执行一条sql,获取数据
def get_datas(sql):
   # 一个传入sql导出数据的函数
   # 跟数据库建立连接
   conn = pms.connect(host='实例地址', user='用户',passwd='密码', 
                           database='库名', port=3306,
                            charset="utf8")
   # 使用 cursor() 方法创建一个游标对象 cursor
   cur = conn.cursor()
   # 使用 execute() 方法执行 SQL
   cur.execute(sql)
   # 获取所需要的数据
   datas = cur.fetchall()
   #关闭连接
   cur.close()
   #返回所需的数据
   return datas(代码可以左右滑动)
2).执行sql,获取字段数据

def get_fields(sql):
   # 一个传入sql导出字段的函数
   conn = pms.connect(host='rm-rj91p2yhl9dm2xmbixo.mysql.rds.xx.com', user='bi-analyzer',
                      passwd='xxx', database='xxx', port=3306, charset="utf8")
   cur = conn.cursor()
   cur.execute(sql)
   # 获取所需要的字段名称
   fields = cur.description
   cur.close()
   return fields(代码可以左右滑动)
03.
数据写入Excel
用Python操作excel其实非常简单。用openpyxl建一个excel对象,然后建一个sheet,接着一个循环把一个一个单元格写数据即可!
 
  
  
  
  
 