Python XlsxWriter业务流量周报表脚本(转载)

一、使用XlsxWriter模块生成Excel表格

安装XlsxWriter模块

pip2.7 install xlsxwriter

官网:http://xlsxwriter.readthedocs.org/

常用方法说明:

Workbook(filename [ options ])用于创建一个workbook对象

创建一个Excel文件

workbook = xlsxwriter.Workbook('chart.xlsx')

add_worksheet(sheetname)用于添加一个工作表,空号中可以指定工作表名称,默认为Sheet1

创建一个工作表对象

worksheet = workbook.add_worksheet()

add_format([properties]) 用于创建一个新的格式对象,参数[properties]为指定一个格式属性的字典如:

bold = workbook.add_format( { 'bold' : True } )

也可以通过Format methods完成格式的设置如:

bold = workbook.add_format()

bold.set_bold( )

worksheet.write(row,column,'data') 用于写入数据到指定位置的单元格row,column,坐标索引的起始位置为0

如果用坐标表示位置的话比如(2,0) 就是 (A3);

这就是表示在A1位置写入'hello'

worksheet.write( 0 , 0 'hello' )

set_row ( row,height,cell_format,options ) 用于设置行单元格的属性,row为指定位置,height设置行高单位像素,cell_format指定定义好的格式对象调用,options设置行hidden(隐藏)、level(组合分级)、collapsed(折叠)操作示例如下:

设置第1行单元格高度为40像素,并调用格式cell_format 。

worksheet.set_row( 0,40,cell_format )

隐藏第2行单元格

worksheet.set_row(1,None,None,{ 'hidden': True })

set_column(first_col,last_col,width,cell_format,options) 用于设置一列或多列单元格属性

bold = workbook.add_format( { 'bold' : True } )

设置0到1(即A到B)列单元格宽度为10像素,并调用加粗格式。

worksheet.set_column( 0,1,bold )

设置C到D列单元格宽度为20像素

worksheet.set_column( C:D,20 )

隐藏E到G列单元格

worksheet.set_column( E:G,None,None,{ 'hidden' : 1} )

insert_image(row,col,image,[options]) 用于插入图片到指定的单元格

插入图片指定图片超链接

worksheet.insert_image('B5',' img/he.jpg ',{'url':'http://python.org'} )

add_chart(type:图表类型) 用于创建图表对象

图表样式:area面积样式、bar条形样式、column柱形样式、line线条样式、pie饼图样式、scatter散点样式、stock股票样式、radar雷达样式;

创建一个column柱形图表

chart = workbook.add_chart({ type,'column' })

在A5单元格插入图表

worksheet.insert_chart( 'A5',chart )

chart.add_series( )用于添加一个数据系列到图表

常用的三个选项:categories作为设置图表类别标签范围,values为设置图标数据范围,line为设置图表线条属性。

chart.add_series({

'categories' : '=Sheet1!$A$1:$A$5',

'values' : '=Sheet1!$B$1:$B$5',

'line' : { 'color' : 'red' },

})

定制自动化业务流量报表周报

订制网站5个频道的流量报表周报,通过XlsxWriter模块将流量数据写入Excel文档,同时自动计算各频道周平均流量,再生成数据报表。

#!/usr/local/python27/bin/python2.7

#coding: utf-8

import sys

reload``(sys)

sys.setdefaultencoding(``'utf-8'``) ``#用于解决windows转linux出现的编码问题

import xlsxwriter

workbook ``= xlsxwriter.Workbook(``'chart.xlsx'``)

worksheet ``= workbook.add_worksheet()

#创建图表对象,定义图表类型。

chart ``= workbook.add_chart({``'type'``:``'column'``})

title ``= [``'业务名称'``,``'星期一'``,``'星期二'``,``'星期三'``,``'星期四'``,``'星期五'``,``'星期六'``,``'星期日'``,``'平均流量'``]

buname ``= [``'业务官网'``,``'新闻中心'``,``'购物频道'``,``'体育频道'``,``'亲子频道'``]

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``.set_border(``1``)

format_title ``= workbook.add_format()

format_title.set_border(``1``)

format_title.set_bg_color(``'#cccccc'``)

format_ave ``= workbook.add_format()

format_ave.set_border(``1``)

format_ave.set_num_format(``'0.00'``)

#使用行写入第一行业务名称及标题

worksheet.write_row(``'A1'``,title,format_title)

#使用列写入从第一列的第二行开始写入频道标题

worksheet.write_column(``'A2'``,buname,``format``)

#从B2开始写入数据项

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

#这里是在求周平均值,I当前行的数据 = B:H当前行的值相加再求平均

worksheet.write_formula(``'I'``+``cur_row, ``'= AVERAGE(B'``+``cur_row``+``':H'``+``cur_row``+``')'``,format_ave)

chart.add_series({

#这里是在工作表Sheet1中指定该图表类别的标签范围,从B1到H1,就是取了周一到周日。

'categories'``: ``'=Sheet1!$B$1:$H$1'``,

#这里是设置图表数据的范围,从B当前数据行到H当前数据行。

'values'``: ``'=Sheet1!$B$'``+``cur_row``+``':$H$'``+``cur_row,

'line' : {``'color'``:``'black'``},

#引用了业务名称为图列项

'name' : ``'=Sheet1!$A$'``+``cur_row,

})

for row ``in range``(``2``,``7``):

chart_series(``str``(row))

#定义图表样式,每一个值都是一个不一样的样式。

chart.set_style(``2``)

#定义图表的大小

chart.set_size({``'width'``:``577``,``'height'``:``287``})

#设置图表上方的大标题

chart.set_title({``'name'``:``'业务流量周报图'``})

#设置图表y轴的小标题

chart.set_y_axis({``'name'``:``'Mb/s'``})

#插入图表到A8的位置

worksheet.insert_chart(``'A8'``,chart)

workbook.close()

|

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