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()
原文地址:https://www.cnblogs.com/fuyuteng/p/12575403.html