1. 程式人生 > >python實現查詢sql後導出到excel並發送郵件

python實現查詢sql後導出到excel並發送郵件

save epo mode 統計 -- success filename receive odi

#coding=utf-8
import sys
import xlwt
import pymysql as MySQLdb #這裏是python3 如果你是python2.x的話,import MySQLdb
import datetime
import time
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.application import MIMEApplication
import os.path


host = ‘XXXXX‘
user = ‘xxxx‘
pwd = ‘xxxxx‘
port = 3306
db = ‘dbname‘
sheet_name = ‘report‘ + time.strftime("%Y-%m-%d")
filename = ‘report_‘ + time.strftime("%Y-%m-%d") + ‘.xls‘
out_path = ‘/home/report/report_‘+ time.strftime("%Y-%m-%d") + ‘.xls‘
print(out_path)
sql = ‘‘‘select * from xxx‘‘‘

def export():
conn = MySQLdb.connect(host,user,pwd,db,charset=‘utf8‘)
cursor = conn.cursor()
count = cursor.execute(sql)
print("查詢出" + str(count) + "條記錄")

#來重置遊標的位置
cursor.scroll(0,mode=‘absolute‘)
#搜取所有結果
results = cursor.fetchall()

# 獲取MYSQL裏面的數據字段名稱
fields = cursor.description
workbook = xlwt.Workbook() # workbook是sheet賴以生存的載體。
sheet = workbook.add_sheet(sheet_name,cell_overwrite_ok=True)

# 寫上字段信息
for field in range(0,len(fields)):
sheet.write(0,field,fields[field][0])

# 獲取並寫入數據段信息
row = 1
col = 0
for row in range(1,len(results)+1):
for col in range(0,len(fields)):
sheet.write(row,col,u‘%s‘%results[row-1][col])

workbook.save(out_path)

_user = "[email protected]"
_pwd = "******"
areceiver = "[email protected],[email protected]"
acc = "[email protected],[email protected]"

#如名字所示Multipart就是分多個部分
msg = MIMEMultipart()
msg["Subject"] =u‘【數據統計_‘ + time.strftime("%Y-%m-%d") + u‘】康復1.0系統_運營數據‘
msg["From"] = _user
msg["To"] = areceiver
msg["Cc"] = acc

def send_email():

#---這是文字部分---
content = ‘‘‘Deal all,
附件是康復1.0系統運營數據,請查收!‘‘‘
part = MIMEText(content,‘plain‘,‘utf-8‘)
msg.attach(part)

#---這是附件部分---
#xls類型附件
file_name = ‘/home/report/‘ + filename
part = MIMEText(open(file_name,‘rb‘).read(), ‘base64‘, ‘gb2312‘)
part["Content-Type"] = ‘application/octet-stream‘
basename = os.path.basename(file_name)
part["Content-Disposition"] = ‘attachment; filename=%s‘ % basename.encode(‘gb2312‘)
msg.attach(part)

s = smtplib.SMTP("smtp.qq.com", timeout=30)#連接smtp郵件服務器,端口默認是25
s.login(_user, _pwd)#登陸服務器
s.sendmail(_user, areceiver.split(‘,‘) + acc.split(‘,‘), msg.as_string())#發送郵件
print("Eamil send successfully")
s.close()


#結果測試
if __name__=="__main__":
export()
send_email()

python實現查詢sql後導出到excel並發送郵件