导语:使用 python-plotly 模块来进行压测数据的绘制,并且生成静态 html 页面结果展示。
不少小伙伴在开发过程中都有对模块进行压测的经历,压测结束后大家往往喜欢使用Excel处理压测数据并绘制数据可视化视图,但这样不能很方便的使用web页面进行数据展示。本文将介绍使用python-plotly模块来进行压测数据的绘制,并且生成静态html页面方便结果展示。
Plotly简介
Plotly是一款使用JavaScript开发的制图工具,提供了与主流数据分析语言交互的API(如:Python, R, MATLAB)。大家可以到官网 https://plot.ly/ 了解更多详细的信息。Plotly能够绘制具有用户交互功能的精美图表。
Python-Plotly 安装
本文档主要是介绍使用plotly的Python API来进行几种简单图表的绘制,更多Plotly的用法请参考 https://plot.ly/python/
Python-Plotly可以使用pip安装,并且最好在Python2.7版本及以上安装使用,如果使用Python2.6版本,请自行安装Python2.7和对应的pip。
Plotly绘图实例
line-plots
绘图效果:
生成的html页面在右上角提供了丰富的交互工具。
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
def line_plots(name): ''' 绘制普通线图 ''' #数据,x为横坐标,y,z为纵坐标的两项指标,三个array长度相同 dataset = { 'x' :[ 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ], 'y' :[ 5 , 4 , 1 , 3 , 11 , 2 , 6 , 7 , 19 , 20 ], 'z' :[ 12 , 9 , 0 , 0 , 3 , 25 , 8 , 17 , 22 , 5 ]} data_g = [] #分别插入 y, z tr_x = Scatter( x = dataset[ 'x' ], y = dataset[ 'y' ], name = 'y' ) data_g.append(tr_x) tr_z = Scatter( x = dataset[ 'x' ], y = dataset[ 'z' ], name = 'z' ) data_g.append(tr_z) #设置layout,指定图表title,x轴和y轴名称 layout = Layout(title = "line plots" , xaxis = { 'title' : 'x' }, yaxis = { 'title' : 'value' }) #将layout设置到图表 fig = Figure(data = data_g, layout = layout) #绘图,输出路径为name参数指定 pltoff.plot(fig, filename = name) |
scatter-plots
绘图效果:
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
def scatter_plots(name): ''' 绘制散点图 ''' dataset = { 'x' :[ 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ], 'y' :[ 5 , 4 , 1 , 3 , 11 , 2 , 6 , 7 , 19 , 20 ], 'text' :[ '5_txt' , '4_txt' , '1_txt' , '3_txt' , '11_txt' , '2_txt' , '6_txt' , '7_txt' , '19_txt' , '20_txt' ]} data_g = [] tr_x = Scatter( x = dataset[ 'x' ], y = dataset[ 'y' ], text = dataset[ 'text' ], textposition = 'top center' , mode = 'markers+text' , name = 'y' ) data_g.append(tr_x) layout = Layout(title = "scatter plots" , xaxis = { 'title' : 'x' }, yaxis = { 'title' : 'value' }) fig = Figure(data = data_g, layout = layout) pltoff.plot(fig, filename = name) |
bar-charts
绘图效果:
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
def bar_charts(name): ''' 绘制柱状图 ''' dataset = { 'x' :[ 'Windows' , 'Linux' , 'Unix' , 'MacOS' ], 'y1' :[ 45 , 26 , 37 , 13 ], 'y2' :[ 19 , 27 , 33 , 21 ]} data_g = [] tr_y1 = Bar( x = dataset[ 'x' ], y = dataset[ 'y1' ], name = 'v1' ) data_g.append(tr_y1) tr_y2 = Bar( x = dataset[ 'x' ], y = dataset[ 'y2' ], name = 'v2' ) data_g.append(tr_y2) layout = Layout(title = "bar charts" , xaxis = { 'title' : 'x' }, yaxis = { 'title' : 'value' }) fig = Figure(data = data_g, layout = layout) pltoff.plot(fig, filename = name) |
pie-charts
绘图效果:
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
def pie_charts(name): ''' 绘制饼图 ''' dataset = { 'labels' :[ 'Windows' , 'Linux' , 'Unix' , 'MacOS' , 'Android' , 'iOS' ], 'values' :[ 280 , 25 , 10 , 100 , 250 , 270 ]} data_g = [] tr_p = Pie( labels = dataset[ 'labels' ], values = dataset[ 'values' ] ) data_g.append(tr_p) layout = Layout(title = "pie charts" ) fig = Figure(data = data_g, layout = layout) pltoff.plot(fig, filename = name) |
filled-area-plots
本例是绘制具有填充效果的堆叠线图,适合分析具有堆叠百分比属性的数据
绘图效果:
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
def filled_area_plots(name): ''' 绘制堆叠填充的线图 ''' dataset = { 'x' :[ 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ], 'y1' :[ 5 , 4 , 1 , 3 , 11 , 2 , 6 , 7 , 19 , 20 ], 'y2' :[ 12 , 9 , 0 , 0 , 3 , 25 , 8 , 17 , 22 , 5 ], 'y3' :[ 13 , 22 , 46 , 1 , 15 , 4 , 18 , 11 , 17 , 20 ]} #计算y1,y2,y3的堆叠占比 dataset[ 'y1_stack' ] = dataset[ 'y1' ] dataset[ 'y2_stack' ] = [y1 + y2 for y1, y2 in zip (dataset[ 'y1' ], dataset[ 'y2' ])] dataset[ 'y3_stack' ] = [y1 + y2 + y3 for y1, y2, y3 in zip (dataset[ 'y1' ], dataset[ 'y2' ], dataset[ 'y3' ])] dataset[ 'y1_text' ] = [ '%s(%s%%)' % (y1, y1 * 100 / y3_s) for y1, y3_s in zip (dataset[ 'y1' ], dataset[ 'y3_stack' ])] dataset[ 'y2_text' ] = [ '%s(%s%%)' % (y2, y2 * 100 / y3_s) for y2, y3_s in zip (dataset[ 'y2' ], dataset[ 'y3_stack' ])] dataset[ 'y3_text' ] = [ '%s(%s%%)' % (y3, y3 * 100 / y3_s) for y3, y3_s in zip (dataset[ 'y3' ], dataset[ 'y3_stack' ])] data_g = [] tr_1 = Scatter( x = dataset[ 'x' ], y = dataset[ 'y1_stack' ], text = dataset[ 'y1_text' ], hoverinfo = 'x+text' , mode = 'lines' , name = 'y1' , fill = 'tozeroy' #填充方式: 到x轴 ) data_g.append(tr_1) tr_2 = Scatter( x = dataset[ 'x' ], y = dataset[ 'y2_stack' ], text = dataset[ 'y2_text' ], hoverinfo = 'x+text' , mode = 'lines' , name = 'y2' , fill = 'tonexty' #填充方式:到下方的另一条线 ) data_g.append(tr_2) tr_3 = Scatter( x = dataset[ 'x' ], y = dataset[ 'y3_stack' ], text = dataset[ 'y3_text' ], hoverinfo = 'x+text' , mode = 'lines' , name = 'y3' , fill = 'tonexty' ) data_g.append(tr_3) layout = Layout(title = "field area plots" , xaxis = { 'title' : 'x' }, yaxis = { 'title' : 'value' }) fig = Figure(data = data_g, layout = layout) pltoff.plot(fig, filename = name) |
小结
本文介绍了利用python-plotly绘制数据图的方法,实例中 线图(line plots)、散点图(scatter plots)、柱状图(bar charts)、饼图(pie charts)以及填充堆叠线图(filled area plots)这五种典型的图表基本上涵盖了大部分类型的测试数据,各位小伙伴可以加以变形绘制出更多的漂亮图标。
文中所示代码:test_plotly.rar
参考资料
1. https://plot.ly/python/basic-charts/
2. https://images.plot.ly/plotly-documentation/images/python_cheat_sheet.pdf
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.qcloud.com/community/article/317573?utm_source=tuicool&utm_medium=referral