123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768 |
- # -*- coding: utf-8 -*-
- # Author: dukun
- 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
- #连接数据库
- def conMysql(mysql_host,mysql_user,mysql_password,mysql_db):
- db = pymysql.connect(host=mysql_host,user=mysql_user, password=mysql_password,db=mysql_db,charset = 'utf8')
- print("数据库连接成功")
- return db
- #获取数据
- def getPassData(sql,db):
- #db = conMysql(mysql_host,mysql_user,mysql_password,mysql_db)
- cursor = db.cursor()
- try:
- # 执行SQL语句
- cursor.execute(sql)
- # 获取所有记录列表
- results = cursor.fetchall()
- #print(results)
- cursor.scroll(0,mode='absolute')
- #cursor.description获取表格的字段信息
- fields=cursor.description
- return results,fields
- except:
- print ("Error: unable to fetch data")
- return 0
- cursor.scroll(0,mode='absolute')
-
- #cursor.description获取表格的字段信息
- fields=cursor.description
- #print(fields)
- cursor.close()
- db.close()
-
- #入表格
- def writeToExcel(fLocate,file_sheet,style1,style2,style3):
- results,fields = getPassData(sql,db)#通道数据
- cus_results,cus_fields = getPassData(cus_sql,db) #客户数据
- ord_results,ord_fields = getPassData(ord_sql,db) #订单时间统计
- mob_results,mob_fields = getPassData(mob_sql,db) #满帆移动次数统计
- uni_results,uni_fields = getPassData(uni_sql,db) #满帆联通次数统计
- tel_results,tel_fields = getPassData(tel_sql,db) #满帆电信次数统计
- ys_results,ys_fields = getPassData(ys_sql,db) #亚杉移动次数统计
- zr_results,zr_fields = getPassData(zr_sql,db) #兆荣移动WT次数统计
- zr_uni_results,zr_uni_fields = getPassData(zr_uni_sql,db) #兆荣联通WT次数统计
- zr_tel_results,zr_tel_fields = getPassData(zr_tel_sql,db) #兆荣电信WT次数统计
- if(results != 0):
- if os.path.exists(fLocate):
- os.remove(fLocate) # 如果文件存在,则删除
- #将查询结果写入到excel
- workbook = xlwt.Workbook(encoding = 'utf-8')
-
- #通道数据表
- sheet = workbook.add_sheet(file_sheet,cell_overwrite_ok=True)
- #通道成功次数表
- sheet2 = workbook.add_sheet("通道成功次数统计",cell_overwrite_ok=True)
- #sheet1 列宽
- for i in range(0,100):
- if i == 1:
- sheet.col(i).width = 256 * 25
- sheet2.col(i).width = 256 * 25
- else:
- sheet.col(i).width = style1.width
- #sheet2 列宽
- for i in range(0,100):
- sheet2.col(i).width = 256 * 15
-
- #sheet.col(2).width = 256 * 100
- #将通道数据表头写入excel
- sheet.write(0,0,"序号",style1)
- sheet.write(0,1,"通道",style1)
- sheet.write(0,2,"面额",style1)
- sheet.write(0,3,"订单数",style1)
- sheet.write(0,4,"金额百分比",style1)
-
- #订单时间统计表头
- sheet2.write_merge(0, 0, 0, 6, 'First Merge',style1)
- sheet2.write(0,0,"订单时间百分比",style1)
- sheet2.write(1,0,"小于10分钟",style1)
- sheet2.write(1,1,"10-20分钟",style1)
- sheet2.write(1,2,"20-30分钟",style1)
- sheet2.write(1,3,"30-40分钟",style1)
- sheet2.write(1,4,"40-50分钟",style1)
- sheet2.write(1,5,"50-60分钟",style1)
- sheet2.write(1,6,"大于60分钟",style1)
- #通道成功次数统计
- sheet2.write_merge(5, 5, 0, 10, 'Second Merge',style1)
- sheet2.write(5,0,"通道成功次数统计",style1)
- sheet2.write(6,0,"通道",style1)
- sheet2.write(6,1,"1-5次",style1)
- sheet2.write(6,2,"6-10次",style1)
- sheet2.write(6,3,"11-15次",style1)
- sheet2.write(6,4,"16-20次",style1)
- sheet2.write(6,5,"21-30次",style1)
- sheet2.write(6,6,"31-40次",style1)
- sheet2.write(6,7,"41-50次",style1)
- sheet2.write(6,8,"51-60次",style1)
- sheet2.write(6,9,"大于60次",style1)
- sheet2.write(6,10,"总订单数",style1)
- sheet2.write(7,0,"满帆移动",style1)
- sheet2.write(8,0,"满帆联通",style1)
- sheet2.write(9,0,"满帆电信",style1)
- sheet2.write(10,0,"亚杉移动",style1)
- sheet2.write(11,0,"兆蓉移动WT",style1)
- sheet2.write(12,0,"兆蓉联通WT",style1)
- sheet2.write(13,0,"兆蓉电信WT",style1)
- sheet2.write(14,0,"总计",style1)
- sheet2.write(15,0,"百分比",style1)
-
- #订单时间统计写入excle
- ord_col = len(ord_fields)
- for j in range(ord_col):
- sheet2.write(2,j,ord_results[0][j],style1)
- #通道成功次数统计写入excle
- mob_col = len(mob_fields)
- for j in range(1,mob_col+1):
- sheet2.write(7,j,mob_results[0][j-1],style1)
- sheet2.write(8,j,uni_results[0][j-1],style1)
- sheet2.write(9,j,tel_results[0][j-1],style1)
- sheet2.write(10,j,ys_results[0][j-1],style1)
- sheet2.write(11,j,zr_results[0][j-1],style1)
- sheet2.write(12,j,zr_uni_results[0][j-1],style1)
- sheet2.write(13,j,zr_tel_results[0][j-1],style1)
- c_row = 14
- #通道成功次数总计栏
- sheet2.write(c_row,1,xlwt.Formula("SUM($B$8:$B${})".format(c_row)),style1)
- sheet2.write(c_row,2,xlwt.Formula("SUM($C$8:$C${})".format(c_row)),style1)
- sheet2.write(c_row,3,xlwt.Formula("SUM($D$8:$D${})".format(c_row)),style1)
- sheet2.write(c_row,4,xlwt.Formula("SUM($E$8:$E${})".format(c_row)),style1)
- sheet2.write(c_row,5,xlwt.Formula("SUM($F$8:$F${})".format(c_row)),style1)
- sheet2.write(c_row,6,xlwt.Formula("SUM($G$8:$G${})".format(c_row)),style1)
- sheet2.write(c_row,7,xlwt.Formula("SUM($H$8:$H${})".format(c_row)),style1)
- sheet2.write(c_row,8,xlwt.Formula("SUM($I$8:$I${})".format(c_row)),style1)
- sheet2.write(c_row,9,xlwt.Formula("SUM($J$8:$J${})".format(c_row)),style1)
- sheet2.write(c_row,10,xlwt.Formula("SUM($K$8:$K${})".format(c_row)),style1)
-
- #通道成功次数百分比
- sheet2.write(c_row+1,1,xlwt.Formula("$B${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,2,xlwt.Formula("$C${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,3,xlwt.Formula("$D${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,4,xlwt.Formula("$E${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,5,xlwt.Formula("$F${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,6,xlwt.Formula("$G${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,7,xlwt.Formula("$H${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,8,xlwt.Formula("$I${}/$K${}".format(c_row+1,c_row+1)),style2)
- sheet2.write(c_row+1,9,xlwt.Formula("$J${}/$K${}".format(c_row+1,c_row+1)),style2)
- #通道数据写入excle
- num = 1
- row = len(results)
- col = len(fields)
- for i in range(1,row+1):
- for j in range(col):
- if j == 0:
- sheet.write(i,j,num,style1)
- num += 1
- else:
- sheet.write(i,j,results[i-1][j],style1)
-
- #客户数据表头
- sheet.write(row+4,0,"序号",style1)
- sheet.write(row+4,1,"客户",style1)
- sheet.write(row+4,2,"面额",style1)
- sheet.write(row+4,3,"订单数",style1)
- sheet.write(row+4,4,"金额百分比",style1)
- #客户数据
- income_money = 0;
- num = 1
- cus_row = len(cus_results)
- cus_col = len(cus_fields)
- for i in range(row+5,row+5 + cus_row):
- for j in range(cus_col):
- if cus_results[i-row-5][0] >= 57:
- #cus_num += 1
- #print('cus_num:{}'.format(cus_num))
- continue
- else:
- if j == 0:
- sheet.write(i,j,num,style1)
- num += 1
- else:
- sheet.write(i,j,cus_results[i-row-5][j],style1)
-
- #总收入
- for i in range(1,cus_row):
- if cus_results[i-1][0] >= 57:
- continue
- else:
- if ('身边科技' in cus_results[i-1][1]):
- income_money = income_money + 0.978 * cus_results[i-1][2]
- #print('身边科技:%d'%income_money)
- elif ('十荟' in cus_results[i-1][1]):
- income_money = income_money + 0.985 * cus_results[i-1][2]
- #print('十荟:%d'%income_money)
- elif ('脉粒' in cus_results[i-1][1]):
- income_money = income_money + 0.984 * cus_results[i-1][2]
- #print('脉粒:%d'%income_money)
- elif ('小米' in cus_results[i-1][1]):
- income_money = income_money + 0.985 * cus_results[i-1][2]
- #print('小米:%d'%income_money)
- elif ('挖财' in cus_results[i-1][1]):
- income_money = income_money + 0.985 * cus_results[i-1][2]
- #print('挖财:%d'%income_money)
- elif ('H5' in cus_results[i-1][1]):
- income_money = income_money + 0.989 * cus_results[i-1][2]
- #print('H5:%d'%income_money)
- elif ('折800' in cus_results[i-1][1]):
- income_money = income_money + 0.985 * cus_results[i-1][2]
- #print('折800:%d'%income_money)
-
-
- #合计栏
- for i in range(0,5):
- #if cus_results[i-row-6][0] >= 57:
- # cus_num += 1
- if i == 0:
- sheet.write(row+1,i,row+1,style1)
- sheet.write(row+num+4,i,num,style1)
- elif i == 1:
- sheet.write(row+1,i,'合计',style1)
- sheet.write(row+num+4,i,'合计',style1)
- elif i == 2:
- sheet.write(row+1,i,xlwt.Formula("SUM($C$%d:$C$%d)"%(2,row+1)),style1)
- sheet.write(row+num+4,i,xlwt.Formula("SUM($C$%d:$C$%d)"%(row+6,row+num+4)),style1)
- elif i == 3:
- sheet.write(row+1,i,xlwt.Formula("SUM($D$%d:$D$%d)"%(2,row+1)),style1)
- sheet.write(row+num+4,i,xlwt.Formula("SUM($D$%d:$D$%d)"%(row+6,row+num+4)),style1)
- else:
- #sheet.write(row+1,i,' ')
- #sheet.write(row+1,i,' ')
- pass
- #print(row)
- #print(col)
- #通道金额百分比
- for i in range(1,row+1):
- j = i + 1
- sheet.write(i,col,xlwt.Formula("$C$%d/$C$%d"%(j,row+2)),style2)
-
- #客户金额百分比
- for i in range(row+5,row+num+4):
- j = i + 1
- sheet.write(i,col,xlwt.Formula("$C$%d/$C$%d"%(j,row+num+5)),style2)
- sheet.write(0,col+2,"网厅百分比",style2)
- sheet.write(0,col+3,"补单面额",style1)
- sheet.write(0,col+4,"均单值[995预估]",style3)
- sheet.write(0,col+5,"均单面值",style3)
-
- supOrder_money = 0 #补单面额
- cost_money = 0 #成本
- net_money = 0 #网厅金额
- sup = 0
- for i in range(1,row+1):
- #for j in rang(col+1):
- #print(results[i-1][1])
- if('补单' in results[i-1][1]):
- supOrder_money += results[i-1][2]
- #print(supOrder_money)
- cost_money += 1.0 * results[i-1][2]
- elif('人工' in results[i-1][1]):
- supOrder_money += results[i-1][2]
- cost_money += results[i-1][2]
- elif('亚杉' in results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.979 * results[i-1][2]
- elif('满帆移动' in results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.979 * results[i-1][2]
- #print(results[i-1][2])
- #print(cost_money)
- elif('满帆联通' in results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.978 * results[i-1][2]
- #print(cost_money)
- elif('满帆电信' in results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.974 * results[i-1][2]
- #print(cost_money)
- elif('兆蓉移动WT' == results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.975 * results[i-1][2]
- #print(cost_money)
- elif('兆蓉联通WT' == results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.972 * results[i-1][2]
- elif('兆蓉电信WT' == results[i-1][1]):
- net_money += results[i-1][2]
- cost_money = cost_money + 0.970 * results[i-1][2]
- elif('兆蓉移动' == results[i-1][1]):
- #print(results[i-1][2])
- cost_money = cost_money + 0.9972 * results[i-1][2]
- #print(cost_money)
- elif('兆蓉联通' == results[i-1][1]):
- cost_money = cost_money + 1.01 * results[i-1][2]
- #print(cost_money)
- elif('兆蓉电信' == results[i-1][1]):
- cost_money = cost_money + 1.0 * results[i-1][2]
- #print(cost_money)
- #print('=========================')
- sheet.write(1,col+2,xlwt.Formula("%d / SUM($C$%d:$C$%d) "%(net_money,2,row+1)),style2)
- sheet.write(1,col+3,supOrder_money,style1)
- sheet.write(1,col+4,xlwt.Formula("0.995 * SUM($C$%d:$C$%d)/SUM($D$%d:$D$%d) "%(2,row+1,2,row+1)),style3)
- sheet.write(1,col+5,xlwt.Formula("SUM($C$%d:$C$%d)/SUM($D$%d:$D$%d) "%(2,row+1,2,row+1)),style3)
- sheet.write(5,col+2,'总成本')
- sheet.write(6,col+2,'总收入')
- sheet.write(7,col+2,'总利润')
- sheet.write(8,col+2,'利润率')
- style4 = xlwt.XFStyle()#设置利润率小数点保留位数
- style4.num_format_str='0.000000000'
- sheet.write(5,col+3,cost_money)
- sheet.write(6,col+3,income_money)
- sheet.write(7,col+3,xlwt.Formula("H7 - H6"))
- sheet.write(8,col+3,xlwt.Formula("H8 / H7 "),style4)
-
-
- workbook.save(fLocate)
- #设置表格样式
- def setStyle():
- #初始化样式
- style1 = xlwt.XFStyle()
- style2 = xlwt.XFStyle()
- style3 = xlwt.XFStyle()
- font = xlwt.Font() # 为样式创建字体
- font.name = '宋体'
- # 设置字体颜色
- #font.colour_index = color
- # 字体大小
- font.height = 20 * 11
-
- #设置边框
- color = 1
- borders = xlwt.Borders()
- borders.left = color
- borders.left = xlwt.Borders.THIN
- borders.right = color
- borders.top = color
- borders.bottom = color
-
- #对齐方式
- al = xlwt.Alignment()
- al.horz = 0x02 # 设置水平居中
- al.vert = 0x01 # 设置垂直居中
- #al.wrap = 1 # 自动换行
-
- #列宽
- width = 256 * 18
-
-
- # 定义格式
- style1.borders = borders
- style1.alignment = al
- style1.font = font
- style1.width = width
-
- style2.borders = borders
- style2.alignment = al
- style2.font = font
- style2.width = width
- style2.num_format_str='0%'
- style3.borders = borders
- style3.alignment = al
- style3.font = font
- style3.width = width
- style3.num_format_str='0.00'
- return style1,style2,style3
-
- def sendMail(sender,receiver,mail_user,mail_pass,mail_host,subject,content,fLocate,file_name):
- try:
- #邮件头
- message = MIMEMultipart()
- message['From'] = "{}".format(sender)#发送
- message['To'] = ",".join(receiver)#收件
- message['Subject'] = Header(subject, 'utf-8')
- message.attach(MIMEText(content, 'plain', 'utf-8'))# 邮件正文
- # 构造附件
- att1 = MIMEText(open(fLocate,'rb').read(), 'plain', 'utf-8')
- #att1 = MIMEApplication(open(fLocate))
- att1["Content-Type"] = 'application/octet-stream'
- #att1["Content-Disposition"] = "attachment; filename=" + file_name
- att1.add_header('Content-Disposition', 'attachment', filename=file_name)
- message.attach(att1)
-
- #执行
- smtp = smtplib.SMTP()
- #smtp.connect(smtpserver) #连接服务器
- smtp = smtplib.SMTP_SSL(mail_host, 465)
- smtp.login(mail_user, mail_pass) #登录
- smtp.sendmail(sender, receiver, message.as_string()) #发送
- smtp.quit()
- print("SEND SUCCES")
- except:
- print("SEND FALSE")
- if __name__ == '__main__':
- #数据库连接信息
- mysql_host = '47.95.217.180'
- mysql_user = 'rtech'
- mysql_password = 'S5RE4dQ65MphYk7F'
- mysql_db = 'fmp'
- #数据库连接
- db = conMysql(mysql_host,mysql_user,mysql_password,mysql_db)
-
- #获取时间
- today = datetime.date.today()
- yesterday = today - datetime.timedelta(days=1)
- yesterdayStart = yesterday.strftime("%Y-%m-%d") + ' 00:00:00'
- yesterdayEnd = yesterday.strftime("%Y-%m-%d") + ' 23:59:59'
-
- #通道sql语句
- sql = """SELECT
- t1.channel_id, access_channel_info.channel_name,t1.flow_amount_sum,t1.count_num
- FROM
- (SELECT
- channel_id,SUM(flow_amount) flow_amount_sum,count(*) count_num
- FROM
- flow_order_info
- WHERE
- apply_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ ' AND
- status = 6 AND
- channel_id NOT IN ( 101,102,103,110,111,112 )
- GROUP BY channel_id) t1 LEFT JOIN access_channel_info
- ON t1.channel_id = access_channel_info.channel_seq_id; """
- #客户sql
- cus_sql = """SELECT
- t1.enterprise_id,customer_name,t1.flow_amount_sum,t1.count_num
- FROM
- (SELECT
- enterprise_id,SUM(flow_amount) flow_amount_sum,count(*) count_num
- FROM
- flow_order_info
- WHERE
- apply_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ ' AND
- status = 6
- GROUP BY enterprise_id)t1 LEFT JOIN customer_info
- ON
- t1.enterprise_id = customer_id; """
-
- #订单时间比例统计sql
- ord_sql = """ SELECT
- CONCAT(CAST(round((A/H)*100,2) AS CHAR),'%') as 'AA[<10min]',
- CONCAT(CAST(round((B/H)*100,2) AS CHAR),'%') as 'BB[10-20min]',
- CONCAT(CAST(round((C/H)*100,2) AS CHAR),'%') as 'CC[20-30min]',
- CONCAT(CAST(round((D/H)*100,2) AS CHAR),'%') as 'DD[30-40min]',
- CONCAT(CAST(round((E/H)*100,2) AS CHAR),'%') as 'EE[40-50min]',
- CONCAT(CAST(round((F/H)*100,2) AS CHAR),'%') as 'FF[50-60min]',
- CONCAT(CAST(round((G/H)*100,2) AS CHAR),'%') as 'GG[>60min]'
- FROM
- (SELECT
- SUM(CASE WHEN diff_time BETWEEN 0 AND 600 THEN 1 ELSE 0 END) AS A,
- SUM(CASE WHEN diff_time BETWEEN 601 AND 1200 THEN 1 ELSE 0 END) AS B,
- SUM(CASE WHEN diff_time BETWEEN 1201 AND 1800 THEN 1 ELSE 0 END) AS C,
- SUM(CASE WHEN diff_time BETWEEN 1801 AND 2400 THEN 1 ELSE 0 END) AS D,
- SUM(CASE WHEN diff_time BETWEEN 2401 AND 3000 THEN 1 ELSE 0 END) AS E,
- SUM(CASE WHEN diff_time BETWEEN 3001 AND 3600 THEN 1 ELSE 0 END) AS F,
- SUM(CASE WHEN diff_time > 3600 THEN 1 ELSE 0 END) AS G,
- COUNT(*) AS H
- FROM
- (SELECT
- (UNIX_TIMESTAMP(check_time) - UNIX_TIMESTAMP(apply_date)) AS diff_time
- FROM
- flow_order_info
- WHERE
- apply_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ ' AND
- status = 6 AND channel_id NOT IN ( 101,102,103,110,111,112 ) ) AS t1 ) AS t2 """
- #满帆移动通道成功次数统计
- mob_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 83 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 83 AND
- flow_order_info.status = 6 )t2; """
- #满帆联通通道成功次数统计
- uni_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 84 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 84 AND
- flow_order_info.status = 6 )t2; """
-
- #满帆电信通道成功次数统计
- tel_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 85 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 85 AND
- flow_order_info.status = 6 )t2; """
- #亚杉移动通道成功次数统计
- ys_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 104 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 104 AND
- flow_order_info.status = 6 )t2; """
- #兆蓉移动WT通道成功次数统计
- zr_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 95 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 95 AND
- flow_order_info.status = 6 )t2; """
-
- #兆蓉联通WT通道成功次数统计
- zr_uni_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 116 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 116 AND
- flow_order_info.status = 6 )t2; """
- #兆蓉电信WT通道成功次数统计
- zr_tel_sql = """SELECT
- SUM(CASE WHEN cnt BETWEEN 0 AND 5 THEN 1 ELSE 0 END) AS 'A[1-5]',
- SUM(CASE WHEN cnt BETWEEN 6 AND 10 THEN 1 ELSE 0 END) AS 'A[6-10]',
- SUM(CASE WHEN cnt BETWEEN 11 AND 15 THEN 1 ELSE 0 END) AS 'A[11-15]',
- SUM(CASE WHEN cnt BETWEEN 16 AND 20 THEN 1 ELSE 0 END) AS 'B[16-20]',
- SUM(CASE WHEN cnt BETWEEN 21 AND 30 THEN 1 ELSE 0 END) AS 'C[21-30]',
- SUM(CASE WHEN cnt BETWEEN 31 AND 40 THEN 1 ELSE 0 END) AS 'D[31-40]',
- SUM(CASE WHEN cnt BETWEEN 41 AND 50 THEN 1 ELSE 0 END) AS 'E[41-50]',
- SUM(CASE WHEN cnt BETWEEN 51 AND 60 THEN 1 ELSE 0 END) AS 'F[51-60]',
- SUM(CASE WHEN cnt > 61 THEN 1 ELSE 0 END) AS 'G[>60]',
- COUNT(*) AS 'H[总订单数]'
- FROM
- ( SELECT
- t1.order_id, t1.cnt
- FROM
- (SELECT
- order_id, COUNT(*) AS cnt
- FROM
- mobile_flow_dispatch_rec
- WHERE
- trans_id = 105 AND
- create_date BETWEEN ' """ + yesterdayStart + """ ' AND ' """ + yesterdayEnd + """ '
- GROUP BY
- order_id
- ORDER BY
- cnt ASC) t1 LEFT JOIN flow_order_info
- ON
- t1.order_id = flow_order_info.order_id
- WHERE
- flow_order_info.channel_id = 105 AND
- flow_order_info.status = 6 )t2; """
-
- #表格信息
- file_sheet = '通道总数'
- file_name = '通道数据' + str(yesterday) + '.xls'
- fLocate = r'/home/dukun/work/passData/' + file_name
-
- #邮件信息
- #sender = 'd2759360205@163.com' #发件人邮箱
- sender = 'youzixifeng@bluefire.top'
- #收件人邮箱,可以多个(列表形式)群发
- receiver = ['fengfei@bluefire.top','steven@bluefire.top','skyzyk@bluefire.top','miaomiao@bluefire.top']
-
- mail_user = 'youzixifeng@bluefire.top' #发件人姓名
- #mail_pass = 'YCHFLABGLFGSLSJZ' #smtp授权163
- mail_pass = 'Dukun864633403'
- mail_host = 'smtp.exmail.qq.com' #邮箱服务器
- subject = "通道数据统计" #邮件标题
- content = ' ' #邮件正文 #邮件正文
- #__file_____
- #file_subject='Gave', 'you', 'a', 'piece', 'of', 'shit.' #sheet标题
-
- style1,style2,style3 = setStyle()
- writeToExcel(fLocate,file_sheet,style1,style2,style3)
- sendMail(sender,receiver,mail_user,mail_pass,mail_host,subject,content,fLocate,file_name)
- print(fLocate)
- """
- while True:
- now = datetime.datetime.now()
- if now.hour == 8 and now.minute == 46:
- style = setStyle()
- writeToExcel(fLocate,file_sheet,style)
- sendMail(sender,receiver,mail_user,mail_pass,mail_host,subject,content,fLocate,file_name)
- #每隔60秒检测一次
- time.sleep(60)
- """
|