python3+mysql查询数据并通过邮件群发excel附件

本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下

连接、查询mysql,导入到excel文件,定时群发邮件与附件。
主要用到pymysql ,smtplib , xlwt

#1、 导入模块

import pymysql #Python3的mysql模块,Python2 是mysqldb
import os
import datetime #定时发送,以及日期
import shutil #文件操作
import smtplib #邮件模块
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.header import Header
import time
import xlwt #excel写入

#2、连接并查询mysql

def eMysql(mysql_host,mysql_port,mysql_user,mysql_password,mysql_db,sql):
  try:
    db = pymysql.connect(host=mysql_host,port=mysql_port,user=mysql_user, password=mysql_password, db=mysql_db,charset = 'utf8')#连接数据库编码注意是utf8,不然中文结果输出会乱码
    print("MYSQL CONNECTED.")# 连接数据库
    cursor = db.cursor()# 使用cursor()方法获取操作游标
    cursor.execute(sql)# 执行SQL语句
    print('SQL EXECUTED')
    results = cursor.fetchall()# 结果
    return results
    print('RESULTS EXECUTED')
    db.close() # 关闭数据库连接
    print('MYSQL CLOSED')
  except:
    print('SQL FAILED')

#3、写入excel

def eWrite(fLocate,results,file_sheet,file_subject,style0):
  try:
    if os.path.exists(fLocate):
      os.remove(fLocate)  # 如果文件存在,则删除
    f = xlwt.Workbook(encoding='utf-8')  #打开excel文件
    fs = f.add_sheet(file_sheet)  #sheet名
    subject = list(file_subject)  #列表化
    for i in range(len(subject)): #找到日期列
      if '日期' in subject[i]:
        col_num=i
    for i in range(len(subject)): #sheet标题
      fs.write(0, i, subject[i])

    for i in range(len(results)): #sheet数据,日期列格式为date
      for j in range(len(results[0])):
        if j== col_num:
          fs.write(i + 1, j, results[i][j],style0)
        else:
          fs.write(i + 1, j, results[i][j])

    for i in range(10): #单元格宽度为
      fs.col(i).width=3333

    print("WRITE FINISHED")
    f.save(fLocate)
  except :
    print ("WRITE FAILED")

#4、发送邮件

def eSend(sender,receiver,username,password,smtpserver,subject,e_content,file_path,file_name):
  try:
#邮件头
    message = MIMEMultipart()
    message['From'] = sender#发送
    message['To'] = ",".join(receiver)#收件
    message['Subject'] = Header(subject, 'utf-8')
    message.attach(MIMEText(e_content, 'plain', 'utf-8'))# 邮件正文

# 构造附件
    att1 = MIMEText(open(file_path+file_name,'rb').read(), 'base64', 'utf-8')
    att1["Content-Type"] = 'application/octet-stream'
    att1["Content-Disposition"] = "attachment;filename="+file_name
    message.attach(att1)

#执行
    smtp = smtplib.SMTP()
    smtp.connect(smtpserver) #连接服务器
    smtp.login(username, password) #登录
    smtp.sendmail(sender, receiver, message.as_string()) #发送
    smtp.quit()
    print("SEND")
  except:
    print("SEND FAILED")

#5、配置与执行

while True:
#配置
  #__time_____
  ehour=5#定时小时
  emin=21#定时分钟
  esec=41#定时秒
  current_time = time.localtime(time.time())   #当前时间date
  cur_time = time.strftime('%H%M', time.localtime(time.time()))       #当前时间str
  #__mysql_____
  mysql_host = mysql_host #登录host
  mysql_port =mysql_port  #登录port
  mysql_user = mysql_user #登录名
  mysql_password = mysql_password #登录密码
  mysql_db = mysql_db #数据库
  sql = sql.encode('utf-8') #sql查询语句编码
  #__email_____
  sender = sender  #发件人邮箱
  receiver = ['453032441@qq.com']  #收件人邮箱,可以多个(列表形式)群发
#
  username = username   #发件人姓名
  password = password  #smtp密码,qq是给你分配一串,163是自己设置
  smtpserver = smtpserver  #邮箱服务器
  subject = "Hey,here's something interesting"   #邮件标题
  e_content = '{0:^27}\n{1:^27}\n{2:^25}\n{3:^25}'.format('i','/  \\','(-----)','(--------)')  #邮件正文 #邮件正文
  #__file_____
  file_path = "D:/"  #文件位置
  file_name="shit.xls"  #文件名
  fLocate = file_path + file_name   #文件路径
  file_subject='Gave', 'you', 'a', 'piece', 'of', 'shit.' #sheet标题
  file_sheet='ok' #sheet名
  style0=xlwt.XFStyle()
  style0.num_format_str='YYYY-MM-DD'
#操作
  if ((current_time.tm_hour == ehour) and (current_time.tm_min == emin) and (current_time.tm_sec == esec)):
    print ("START")
    results=eMysql(mysql_host,mysql_port,mysql_user,mysql_password,mysql_db,sql)
    eWrite(fLocate, results, file_sheet, file_subject,style0)
    eSend(sender, receiver, username, password, smtpserver, subject, e_content, file_path,file_name)
    print(cur_time)
  time.sleep(1)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

您可能感兴趣的文章:

  • python实现自动发送邮件发送多人、群发、多附件的示例
  • Python群发邮件实例代码
  • Python3实现带附件的定时发送邮件功能
  • python自动发邮件库yagmail的示例代码
  • python实现远程通过网络邮件控制计算机重启或关机
  • python 七种邮件内容发送方法实例
  • python发送邮件的实例代码(支持html、图片、附件)
  • python中使用smtplib和email模块发送邮件实例
  • 详细讲解用Python发送SMTP邮件的教程
  • Python实现SMTP发送邮件详细教程
(0)

相关推荐

  • python中使用smtplib和email模块发送邮件实例

    SMTP模块 这么多已定义的类中,我们最常用的的还是smtplib.SMTP类,就具体看看该类的用法:smtp实例封装一个smtp连接,它支持所有的SMTP和ESMTP操作指令,如果host和port参数被定义,则smtp会在初始化期间自动调用connect()方法,如果connect()方法失败,则会触发SMTPConnectError异常,timeout参数设置了超时时间.在一般的调用过程中,应该遵connetc().sendmail().quit()步骤. SMTP模块主要方法 下面我们来

  • Python实现SMTP发送邮件详细教程

    简介 Python发送邮件的教程本人在网站搜索的时候搜索出来了一大堆,但是都是说了一大堆原理然后就推出了实现代码,我测试用给出的代码进行发送邮件时都不成功,后面找了很久才找到原因,这都是没有一个详细的环境调试导致,所以今天特出一个详细的教程,一步一步从环境调试到代码实现整一个教程,希望对还在苦苦寻找解决方法却迟迟不能得到有效解决的人员一点帮助. SMTP协议 首先了解SMTP(简单邮件传输协议),邮件传送代理程序使用SMTP协议来发送电邮到接收者的邮件服务器.SMTP协议只能用来发送邮件,不能用

  • Python3实现带附件的定时发送邮件功能

    本文实例为大家分享了Python3定时发送邮件功能的具体代码,供大家参考,具体内容如下 1. 导入模块 import os import datetime #定时发送,以及日期 import shutil #文件操作 import smtplib #邮件模块 from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from email.header import Header impo

  • python实现自动发送邮件发送多人、群发、多附件的示例

    1.最近公司实现部分数据统计.分析的报表进行每天定时发送到相关人员的邮箱之中的配置代码被人为删除了,需要重新恢复该功能,由于原先是在linux上使用shell配置发送,实在是太繁琐,所以准备使用python来实现该功能,不过发现网上各种文档都是未经过整理,代码写的很不友善,比如发送多人的只能发送前一个邮箱,附件写死不灵活等等,故特写一遍比较记录. 主要会遇到的几个问题: 1.smtplib.SMTPAuthenticationError: (550, b'User has no permissi

  • 详细讲解用Python发送SMTP邮件的教程

    SMTP是发送邮件的协议,Python内置对SMTP的支持,可以发送纯文本邮件.HTML邮件以及带附件的邮件. Python对SMTP支持有smtplib和email两个模块,email负责构造邮件,smtplib负责发送邮件. 首先,我们来构造一个最简单的纯文本邮件: from email.mime.text import MIMEText msg = MIMEText('hello, send by Python...', 'plain', 'utf-8') 注意到构造MIMEText对象时

  • python自动发邮件库yagmail的示例代码

    之前使用的python的smtplib.email模块发模块的一步步骤是: 一.先导入smtplib模块  导入MIMEText库用来做纯文本的邮件模板 二.发邮件几个相关的参数,每个邮箱的发件服务器不一样,以126为例子百度搜索服务器是  smtp.126.com 三.写邮件主题和正文,这里的正文是HTML格式的 四.最后调用SMTP发件服务 一般发邮件方法 我以前在通过Python实现自动化邮件功能的时候是这样的: import smtplib from email.mime.text im

  • python 七种邮件内容发送方法实例

    一.文件形式的邮件 复制代码 代码如下: #!/usr/bin/env python3#coding: utf-8import smtplibfrom email.mime.text import MIMETextfrom email.header import Header sender = '***'receiver = '***'subject = 'python email test'smtpserver = 'smtp.163.com'username = '***'password

  • Python群发邮件实例代码

    直接上代码了 复制代码 代码如下: import smtplibmsg = MIMEMultipart() #构造附件1att1 = MIMEText(open('/home/a2bgeek/develop/python/hello.py', 'rb').read(), 'base64', 'gb2312')att1["Content-Type"] = 'application/octet-stream'att1["Content-Disposition"] = '

  • python实现远程通过网络邮件控制计算机重启或关机

    需求分析: python实现一个远程通过网络邮件控制计算机重启或关机的项目. 程序流程: 过程分析: 要实现本功能,首先要直到在本地如何通过Python控制计算机的重启和关机,然后需要知道如何远程发送消息给Python程序.可以在Python中执行CMD命令控制计算机的重启和关机,把发送电子邮件作为远程控制的渠道.Python程序自动登录邮箱检测邮件,当发送关机指令给这个邮箱时,则执行关机命令. 1.通过os.system()函数执行CMD命令 import os os.system('shut

  • python发送邮件的实例代码(支持html、图片、附件)

    第一段代码: 复制代码 代码如下: #!/usr/bin/python# -*- coding: utf-8 -*- import emailimport mimetypesfrom email.MIMEMultipart import MIMEMultipartfrom email.MIMEText import MIMETextfrom email.MIMEImage import MIMEImageimport smtplib def sendEmail(authInfo, fromAdd

随机推荐