Python数据统计导出excel

需求就是统计每天客户端开机数据,将开机率低于30%的数据导出,每天发送邮件给相关业务人员。

  • 查询数据
  • 整理excel
  • 发送邮件

一、数据查询方法(此项可根据实际业务需求更改)

 def getUpRate(project_id):
       val = str(1)
       sql = "select rateNum from tablename where project_id=" + str(project_id)
       cursor.execute(sql)
       rateNum = cursor.fetchone()
       if type(rateNum) != tuple :
               insert_sql = "insert into tablename (project_id,rateNum) values('"+ str(project_id) + "','" + val + "')"
               cursor.execute(insert_sql)
               db.commit()
               return val
       else:
               i = rateNum[0]+1
               update_sql = "update tablename set rateNum="+str(i)+" where project_id=" + str(project_id)
               cursor.execute(update_sql)
               db.commit()
               return i

二、数据生成excel

#create excel
s = 0;
wb = xlwt.Workbook(encoding = 'utf-8')
sh = wb.add_sheet('hotel')
sh.write(0,0,'project_id')
sh.write(0,1,'项目名称')
sh.write(0,2,'设备总数')
sh.write(0,3,'开机数')
sh.write(0,4,'异常累计天数')
for project in res:
       s=s+1
       err_num = getUpRate(project[1])
       sh.write(s,0,project[1])
       sh.write(s,1,project[2])
       sh.write(s,2,project[3])
       sh.write(s,3,project[4])
       sh.write(s,4,err_num)
wb.save("example-"+ Yesterday + ".xls")
sendMail()  #发送邮件方法,下方详情

三、发送邮件方法介绍

def sendMail():
        host_server = 'smtp.qq.com' #根据实际情况写
        sender_qq = '123@qq.com' #根据实际情况写
        pwd = '123@123'  #根据实际情况写

        #发件人的邮箱
        sender_qq_mail = '123@qq.com' #根据实际情况写
        #收件人邮箱
        receiver = '456@qq.com'#根据实际情况写
        #邮件的正文内容
        mail_content = "你好,<p>每日统计项目数据,请查收附件</p>"
        #邮件标题
        mail_title = 'xxx数据统计'
        #邮件正文内容
        msg = MIMEMultipart()
        #msg = MIMEText(mail_content, "plain", 'utf-8')
        msg["Subject"] = Header(mail_title, 'utf-8')
        msg["From"] = sender_qq_mail
        msg["To"] = Header("运维通知邮件组", 'utf-8') ## 接收者的别名
        #邮件正文内容
        msg.attach(MIMEText(mail_content, 'html', 'utf-8'))
        # 构造附件1,传送当前目录下的 test.txt 文件
        att1 = MIMEText(open("example-"+Yesterday+".xls", 'rb').read(), 'base64', 'utf-8')
        att1["Content-Type"] = 'application/octet-stream'
        # 这里的filename可以任意写,写什么名字,邮件中显示什么名字
        att1["Content-Disposition"] = 'attachment; filename="example.xls"'
        msg.attach(att1)
        #ssl登录
        smtp = SMTP_SSL(host_server)
        #set_debuglevel()是用来调试的。参数值为1表示开启调试模式,参数值为0关闭调试模式
        smtp.set_debuglevel(1)
        smtp.ehlo(host_server)
        smtp.login(sender_qq, pwd)
        smtp.sendmail(sender_qq_mail, receiver, msg.as_string())
        smtp.quit()

导出excel如遇到下图报错:
1.排查编码 #coding:utf-8 sys.setdefaultencoding('utf8')
2.写入第一行数据的中文字符,或者字符串需要有引号,忽略会报错。

Traceback (most recent call last):
  File "excel.py", line 19, in <module>
    wb.save('example.xls')
  File "/usr/lib/python2.7/site-packages/xlwt/Workbook.py", line 643, in save
    doc.save(filename, self.get_biff_data())
  File "/usr/lib/python2.7/site-packages/xlwt/Workbook.py", line 618, in get_biff_data
    shared_str_table   = self.__sst_rec()
  File "/usr/lib/python2.7/site-packages/xlwt/Workbook.py", line 580, in __sst_rec
    return self.__sst.get_biff_record()
  File "/usr/lib/python2.7/site-packages/xlwt/BIFFRecords.py", line 77, in get_biff_record
    self._add_to_sst(s)
  File "/usr/lib/python2.7/site-packages/xlwt/BIFFRecords.py", line 92, in _add_to_sst
    u_str = upack2(s, self.encoding)
  File "/usr/lib/python2.7/site-packages/xlwt/UnicodeUtils.py", line 50, in upack2
    us = unicode(s, encoding)
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe9 in position 0: ordinal not in range(128)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,490评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,581评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,830评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,957评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,974评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,754评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,464评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,847评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,995评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,137评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,819评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,482评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,023评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,149评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,409评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,086评论 2 355

推荐阅读更多精彩内容

  • 女儿出生以后,老婆一直都是坚持放在我们身边,不管多么辛苦,这是她从一名幼儿园老师角度认为必须坚持的。所以我们见证了...
    扬扬稻籽阅读 194评论 1 1
  • 回想元旦那一天,本该是团聚喜庆的日子,我却那么憋屈想哭。于是躲在房间里,我哭了半天。 元旦那天包饺子,公公盘腿刚在...
    真冉阅读 309评论 5 4
  • ——大战校招十八罗汉终磨一剑 这是一篇失败者的独奏曲,是没念好书就出来断斤卖的苦逼求职者跪出来的一条路。 写这篇文...
    VincentLeung阅读 3,586评论 0 8
  • 如果写作能为你带来名声,那么如何用名声帮你更好地创作? 如果技能精进能让你获得成功,那么如何用成功让你更加精进? ...
    我我悠悠阅读 276评论 0 0
  • 背景知识 泡菜,古称葅,是指为了利于长时间存放而经过发酵的蔬菜。 我国最早的诗集《诗经》中有“中田有庐,疆场有瓜是...
    姜地主阅读 1,111评论 1 4