您的位置:永利集团登录网址 > 计算机教学 > Python XlsxWriter业务流量周报表脚本(转载)

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

2019-10-03 22:49

正文介绍python操作excel的不二秘诀(xlsxwriter包的利用),具体内容如下

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

xlsxwriter包的设置

安装XlsxWriter模块

pip install xlsxwriter

pip2.7 install xlsxwriter

Workbook类

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

成立多个excel文件

常用方法求证:

filename = "test.xlsx"
# Workbook代表整个电子表格文件,并且存储在磁盘上。filename为字符串类型,表示创建的excel文件存储路径;
wb = xlsxwriter.Workbook(filename)

Workbook(filename [ options ])用于创设贰个workbook对象

创立三个sheet表:add_worksheet

创制二个Excel文件

add_worksheet([sheetname])方法,用于增加贰个新的职业表,sheetname为专门的学业表名称,暗中同意是sheet1,比如:

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

ws = wb.add_worksheet() #创建一个sheet1的表
ws2 = wb.add_worksheet("test") #创建一个test的表

add_worksheet(sheetname)用于增多三个专业表,空号中可以钦命专门的学问表名称,默许为Sheet1

设置sheet表单元格的行高和列宽

成立二个工作表对象

set_row(row, height)方法,用于设定某一行单元格的行高
(row:钦赐行职责,开头下标为0;height:为float类型,设定行高,单位像素)
set_column(first_col, last_col, width)方法,用于安装一列或多列单元格的列宽
(irst_col:整型,钦赐早先列地点,开首下标为0;last_col:整型,钦命甘休列地方,起先下标为0;width:float类型,设置列宽)
set_column(“first_col:last_col”, width)方法(first_col和last_col用乌Crane语字母表示列名,最早为A)

worksheet = workbook.add_worksheet()

# 设置sheet表单元格列宽
ws.set_column(0,3,40) #设定第1到4列的列宽为40
ws.set_column("A:A", 40) #设定A列列宽为40
ws.set_column("B:D", 15) #设定B、C、D三列的列宽为15
ws.set_column("E:F", 50) #设定E、F列的列宽为50

#设置sheet表单元格行高
ws.set_row(0,40) #设置第一行的高度为40

add_format([properties]) 用于创立三个新的格式对象,参数[properties]为钦点多少个格式属性的字典如:

Python XlsxWriter业务流量周报表脚本(转载)。向单元格中写入内容:write

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

write(row, col, data,cell_format)方法:是用来将普通数据写入单元格中(行标、列标、内容、单元格格式)

也得以通过Format methods落成格式的设置如:

# 为了简化不同数据类型的写入过程,write方法已作为其他更加具体的数据类型方法的别名,如:
write.string():写入字符串类型数据
wirte_number():写入数字型数据
write_blank():写入空类型数据
write_formula():写入公式型数据
write_datetime():写入日期型数据
wirte_boolean():写入逻辑型数据
write_url():写入超链接型数据

# 示例:
ws.write(1,1,"python操作excel") #在单元格1行1列中写入:“python操作excel”

bold = workbook.add_format()

单元格常用格式

bold.set_bold( )

#设定整个sheet表的单元格的格式

property = {
      'font_size': 11,#字体大小
      'bold':True, #是否加粗
      'align': 'left',#水平对齐方式
      'valign': 'vcenter',#垂直对齐方式
      'font_name': u'微软雅黑',
      'text_wrap': False, # 是否自动换行
      }
cell_format = wb.add_format(property)

#在向单元格中写入内容时,加上单元格样式
ws.write(row,col,data,cell_format)

worksheet.write(row,column,'data') 用于写入数据到钦命地点的单元格row,column,坐标索引的苗子地方为0

单元格中插入图片

如果用坐标表示地方的话比方(2,0) 便是 (A3);

insert_image(row, col, image[, options])方法,用于插入图片到内定的单元格,支持PNG,JPEG,BMP等三种格式。
row:行坐标,起首索引值为0;
col:列坐标,开端索引值为0;
image:string类型,是图表路线;
options:dict类型,是可选参数,用于内定图片地点,如UXC60L等音讯;

那正是意味着在A1职分写入'hello'

# 图片格式
img_format={
      'x_offset': 8,#水平偏移
      'y_offset': 14,#垂直偏移
      'x_scale': 0.18,#水平缩放
      'y_scale': 0.18,#垂直缩放
      'url': None,
      'tip': None,
      'image_data': None,
      'positioning': None
      }
# 示例:
ws.insert_image(1,1,'1.png',img_format)

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为设置Logo数据范围,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()

|

本文由永利集团登录网址发布于计算机教学,转载请注明出处:Python XlsxWriter业务流量周报表脚本(转载)

关键词:

  • 上一篇:没有了
  • 下一篇:没有了