zoukankan      html  css  js  c++  java
  • Python之XlsxWriter模块(数据报表)

    利用python的XlsxWriter模块进行数据报表操作

    import xlsxwriter
    workbook = xlsxwriter.Workbook('chart.xlsx') #创建一个excel文件
    worksheet = workbook.add_worksheet() #创建一个工作表对象
    chart =workbook.add_chart({'type': 'column'}) #创建一个柱状图
    #定义数据表头列表
    title = [u'业务名称',u'星期一',u'星期二',u'星期三',u'星期四',u'星期五',u'星期六',u'星期日',u'平均流量']
    #定义5个频道一周7天的数据列表
    buname = [u'业务官网',u'新闻中心',u'购物频道',u'体育频道',u'亲子频道']
    
    data = [[150,152,158,149,155,145,148],
            [89,88,95,93,98,100,99],
            [201,200,198,175,170,198,195],
            [75,77,78,78,74,70,79],
            [88,85,87,90,93,88,84],
            ]
    format = workbook.add_format() #定义format格式对象
    format.set_border(1) #定义format对象单元格边框加粗的格式
    
    format_titile = workbook.add_format() #定义format_title 格式对象
    format_titile.set_border(1) #定义format_titile 对象单元格边框加粗的格式
    format_titile.set_bg_color('#cccccc')#定义format_titile对象单元格背景颜色
    format_titile.set_align('center')#定义format_titile对象单元格对齐方式
    format_titile.set_bold()#定义format_titile对象内容加粗
    
    format_ave =workbook.add_format()#定义format_ave格式对象
    format_ave.set_border(1) #边框加粗的格式
    format_ave.set_num_format('0.00') #定义format_ave对象单元格数字类别显示格式
    #下面分别以行或列写入方式将标题、业务名称、流量数据写入起初的单元格
    worksheet.write_row('A1',title,format_titile)
    worksheet.write_column('A2',buname,format)
    worksheet.write_row('B2',data[0],format)
    worksheet.write_row('B3',data[1],format)
    worksheet.write_row('B4',data[2],format)
    worksheet.write_row('B5',data[3],format)
    worksheet.write_row('B6',data[4],format)
    
    #定义图表数据系列函数
    def chart_series(cur_row):
        worksheet.write_formula('I'+ cur_row,'=AVERAGE(B'+cur_row+':H'+cur_row+')',format_ave)
        chart.add_series({
            'categoriese': '=Sheet1!$B$1:$H$1',
            'values': '=Sheet1!$B$'+cur_row+':$H$'+cur_row,
            'line': {'color': 'black'}, #线条定义为黑色
            'name': '=Sheet1!$A$'+cur_row,
        })
    for row in range(2,7): #数据域以第2-6行进行图表数据系列函数调用
        chart_series(str(row))
    
    chart.set_size({'wdith':577,'height':287}) #定义图表大小
    chart.set_title({'name':u'业务流量周报报表'}) #定义图表标题
    chart.set_y_axis({'name':'Mb/s'}) #设置y轴小标题
    worksheet.insert_chart('A8',chart)#插入图表在A8
    workbook.close()
  • 相关阅读:
    linux报错-bash: ./xx.sh: Permission denied
    shell脚本报错:-bash: xxx: /bin/bash^M: bad interpreter: No such file or directory
    点灯
    笑话
    bzoj 4898: [Apio2017]商旅
    bzoj 4446: [Scoi2015]小凸玩密室
    bzoj 4237: 稻草人
    idea
    springmvc集成swagger实现接口文档自动化生成
    基本的内存泄漏的解释
  • 原文地址:https://www.cnblogs.com/fuyuteng/p/12575403.html
Copyright © 2011-2022 走看看