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()