Python 脚本学习笔记(四) 定制业务质量报表

一、使用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()

二、实现TCP探测目标服务器路由轨迹

scapy模块需要tcpdump支持,生成报表需要graphviz,ImageMagick 图像处理包支持。

yum install tcpdump graphviz ImageMagick -y

安装scapy模块

pip2.7 install scapy

#!/usr/local/python27/bin/python2.7
#coding: utf-8
 
import os,sys,time,subprocess
import warnings,logging
 
#屏蔽无用的告警信息 
warnings.filterwarnings("ignore",category=DeprecationWarning)
#屏蔽模块IPV6多余告警
logging.getLogger("scapy.runtime").setLevel(logging.ERROR)
from scapy.all import traceroute
 
domains = raw_input(" Please input one or more IP/domain: ")
#切片空格,这里就相当于把domains的内容,放到target列表中,可以通过target[number]调用;
target = domains.split(‘ ‘)
 
dport = [80]
 
if len(target) >= 1 and target[0] !=‘‘:
#启动路由跟踪
        res,unans = traceroute(target,dport=dport,retry=-2)
#res保存的是路由跟踪抓的报文数据,通过res.graph方法生成.svg文件;        
        res.graph(target="> test.svg")
        time.sleep(1)
#调用shell命令,将svg转成png,svg文件可以在浏览器中打开;        
        subprocess.Popen("/usr/bin/convert test.svg test.png",shell=True)
else:
    print "IP/domain Number of errors,exit"

时间: 2024-10-24 18:29:11

Python 脚本学习笔记(四) 定制业务质量报表的相关文章

2. 蛤蟆Python脚本学习笔记二基本命令畅玩

2. 蛤蟆Python脚本学习笔记二基本命令畅玩 本篇名言:"成功源于发现细节,没有细节就没有机遇,留心细节意味着创造机遇.一件司空见惯的小事或许就可能是打开机遇宝库的钥匙!" 下班回家,咱先来看下一些常用的基本命令. 欢迎转载,转载请标明出处:http://blog.csdn.net/notbaron/article/details/48092873 1.  数字和表达式 看下图1一就能说明很多问题: 加法,整除,浮点除,取模,幂乘方等.是不是很直接也很粗暴. 关于上限,蛤蟆不太清楚

3. 蛤蟆Python脚本学习笔记三字符串

3. 蛤蟆Python脚本学习笔记三字符串 本篇名言:"平静的湖面只有呆板的倒映,奔腾的激流才有美丽的浪花!幸福不是靠别人来布施,而是要自己去赢取!生命的意义在不断挑战自己,战胜自己!" 这个本来放在昨天的,由于昨晚又太晚了,所以就搁在这里了.赶紧看看吧. 字符串两边都用双引号或者单引号包起来.否则就使用转移符号来转移一下. 输入在一起可以直接拼接. 欢迎转载,转载请标明出处:http://blog.csdn.net/notbaron/article/details/48112507

1.蛤蟆Python脚本学习笔记一环境搭建

1.蛤蟆Python脚本学习笔记一环境搭建 蛤蟆一直在想在工作的时候能不能有一个牛逼的工具来让自己工作更加轻松和快乐.用过C, C++, C#, JAVA,  SHELL,TCL,汇编,BAT等,感觉这些都是需要的时候能发挥作用,不能和我想象的一样.突然有一天,感觉Python实在不错,那么就和小伙伴们一起乐呵乐呵呗.万事开头难,我们先来搭建环境吧. 欢迎转载,转载请标明出处:http://blog.csdn.net/notbaron/article/details/48058315 1. 相关

Python个人学习笔记四

                                        本节主要学习python语言中网络相关知识. 一 主要文件和目录在Urllib的request.py模块下面.其中支持SSL加密方式访问. 下面我们看看其中的主要类和函数吧. 先看看源码吧. def urlopen(url, data=None, timeout=socket._GLOBAL_DEFAULT_TIMEOUT, *, cafile=None, capath=None, cadefault=False):

Python 脚本学习笔记(五)集中式病毒扫描,端口扫描以及分段数据库操作

Clam AntiVirus是一个免费而且开放源码的防毒软件,软件与病毒库的更新由开源社区免费发布,目前ClamdAV主要为Linux.Uinux系统提供病毒扫描查杀pyClamad是一个python的第三方模块,可让python直接使用ClamAV病毒扫描守护进程clamd来实现一个高效的病毒检测功能. 一.实现集中式的病毒扫描 1.安装clamavp clamd 服务的相关程序包 yum install clamav clamd clamav-update -y chkconfig clam

3、python自动化运维——定制业务质量报表

通过psutil和rrdtool模块相结合绘制网卡网络流量 实例代码: ./cretea.py #!/usr/bin/python   import time   import rrdtool     cur_time=str(int(time.time()))   rrd=rrdtool.create('Flow.rrd','--step','300','--start',cur_time,         'DS:eth0_in:COUNTER:600:0:U',         'DS:e

【原】Learning Spark (Python版) 学习笔记(四)----Spark Sreaming与MLlib机器学习

本来这篇是准备5.15更的,但是上周一直在忙签证和工作的事,没时间就推迟了,现在终于有时间来写写Learning Spark最后一部分内容了. 第10-11 章主要讲的是Spark Streaming 和MLlib方面的内容.我们知道Spark在离线处理数据上的性能很好,那么它在实时数据上的表现怎么样呢?在实际生产中,我们经常需要即使处理收到的数据,比如实时机器学习模型的应用,自动异常的检测,实时追踪页面访问统计的应用等.Spark Streaming可以很好的解决上述类似的问题. 了解Spar

[简明python教程]学习笔记之编写简单备份脚本

[[email protected] 0503]# cat backup_ver3.py #!/usr/bin/python #filename:backup_ver3.py import os import time #source source=['/root/a.sh','/root/b.sh','/root/c.sh'] #source='/root/c.sh' #backup dir target_dir='/tmp/' today=target_dir+time.strftime('

linux学习笔记四(shell编程)

前言:最近在学习shell编程,shell编程是一个很强大的编程语言. 目的:方便今后复习. 内容:1.简单的回顾一下编程语言                 1)编程语言:机器语言,汇编语言,高级语言.                 2)编程语言有静态和动态的区分.                             区别:静态语言是一种编译性的语言,要提前知道变量的格式,进过完整的编译之后才能运行,典型的静态语言包括:C.C++.JAVA.C#.