官网地址:https://openpyxl.readthedocs.io/en/stable/charts/line.html#id1

openpyxl+pandas

# coding=utf-8
import pandas as pd
import time
from openpyxl import Workbook
from openpyxl.chart import (
LineChart,
Reference,
)
from openpyxl.chart.axis import DateAxis def cpu_info(csv_path="./datas-permon/CPU_20200111005156.csv"):
df = pd.read_csv(csv_path) #dtype={'timeStamp':str}
df['timeStamp'] = df['timeStamp'].apply(lambda x:time.strftime('%Y%m%d%H%M%S'
,time.localtime(int(str(x)[:10]))))
user=df.loc[df.label=="192.168.110.151 CPU user"][["label","timeStamp","elapsed"]]
iowait=df.loc[df.label=="192.168.110.151 CPU iowait"][["label","timeStamp","elapsed"]]
idle=df.loc[df.label=="192.168.110.151 CPU idle"][["label","timeStamp","elapsed"]]
it=df["timeStamp"].drop_duplicates().values.tolist()
t=[ str(i) for i in it]
u=user["elapsed"].values.tolist()
io=iowait["elapsed"].values.tolist()
idl=idle["elapsed"].values.tolist()
rows=list(zip(t,u,io,idl))
rows.insert(0,["timeStamp","user","iowait","idle"])
return rows def mem_info(csv_path="./datas-permon/Meminfo_20200111005156.csv"):
df=pd.read_csv(csv_path)
df['timeStamp'] = df['timeStamp'].apply(lambda x:time.strftime('%Y%m%d%H%M%S'
,time.localtime(int(str(x)[:10]))))
total=df.loc[df.label=="192.168.110.151 Memory total"][["label","timeStamp","elapsed"]]
used=df.loc[df.label=="192.168.110.151 Memory used"][["label","timeStamp","elapsed"]]
free=df.loc[df.label=="192.168.110.151 Memory free"][["label","timeStamp","elapsed"]]
tol=total["elapsed"]/1024/1024/1024
us=used["elapsed"]/1024/1024/1024
fr=free["elapsed"]/1024/1024/1024
it = df["timeStamp"].drop_duplicates().values.tolist()
t = [str(i) for i in it]
to=tol.values.tolist()
f=fr.values.tolist()
u=us.values.tolist()
rows=list(zip(t,to,u,f))
rows.insert(0,["timestamp","total","used","free"])
return rows def network_info(csv_path="./datas-permon/NetIO_20200111005156.csv"):
df=pd.read_csv(csv_path)
df['timeStamp'] = df['timeStamp'].apply(lambda x:time.strftime('%Y%m%d%H%M%S'
,time.localtime(int(str(x)[:10]))))
send=df.loc[df.label=="192.168.110.151 Network I/O bytessent"][["label","timeStamp","elapsed"]]
recv=df.loc[df.label=="192.168.110.151 Network I/O bytesrecv"][["label","timeStamp","elapsed"]]
elapsed_send=send["elapsed"].values.tolist()
elapsed_recv=recv["elapsed"].values.tolist()
it = df["timeStamp"].drop_duplicates().values.tolist()
t = [str(i) for i in it]
rows=list(zip(t,elapsed_send,elapsed_recv))
rows.insert(0,["timeStamp","sentBytes","recvBytes"])
return rows def performance_util(configurations):
wb = Workbook()
for configuration in configurations:
rows = configuration["rows"]
sheet = configuration["sheet_name"]
label_max=configuration["label"]
ws = wb.create_sheet(sheet, index=configuration["index"])
for row in rows:
ws.append(row)
data = Reference(ws, min_col=2, min_row=1, max_col=label_max, max_row=len(rows)-1) # max_row=7
# Chart with date axis
c2 = LineChart()
c2.title = "Date Axis"
c2.style = 7
c2.y_axis.title = "Size"
c2.y_axis.crossAx = 500
c2.x_axis = DateAxis(crossAx=100)
c2.x_axis.number_format = '%Y%m%d%H%M%S'
# c2.x_axis.majorTimeUnit = "days"
c2.x_axis.title = "Date"
c2.height = 16
c2.width = 28
c2.add_data(data, titles_from_data=True)
dates = Reference(ws, min_col=1, min_row=2, max_row=len(rows)-1) # max_row=7
c2.set_categories(dates)
ws.add_chart(c2, "F1")
wb.save("line_permon.xlsx") if __name__ == '__main__':
cpu_dict={"rows":cpu_info(),"sheet_name":"CPU","index":0,"label":4}
mem_dict={"rows":mem_info(),"sheet_name":"Mem","index":1,"label":4}
network_dict = {"rows": network_info(), "sheet_name": "NetWork", "index": 2,"label":3}
performance_util([cpu_dict,mem_dict,network_dict])
# network_info()

  效果图:

mem:

network:

pandas 数据可视化之折线图的更多相关文章

  1. 第四篇:R语言数据可视化之折线图、堆积图、堆积面积图

    折线图简介 折线图通常用来对两个连续变量的依存关系进行可视化,其中横轴很多时候是时间轴. 但横轴也不一定是连续型变量,可以是有序的离散型变量. 绘制基本折线图 本例选用如下测试数据集: 绘制方法是首先 ...

  2. Echarts数据可视化series-radar雷达图,开发全解+完美注释

    全栈工程师开发手册 (作者:栾鹏) Echarts数据可视化开发代码注释全解 Echarts数据可视化开发参数配置全解 6大公共组件详解(点击进入): title详解. tooltip详解.toolb ...

  3. Echarts数据可视化series-line线图,开发全解+完美注释

    全栈工程师开发手册 (作者:栾鹏) Echarts数据可视化开发代码注释全解 Echarts数据可视化开发参数配置全解 6大公共组件详解(点击进入): title详解. tooltip详解.toolb ...

  4. Echarts数据可视化series-graph关系图,开发全解+完美注释

    全栈工程师开发手册 (作者:栾鹏) Echarts数据可视化开发代码注释全解 Echarts数据可视化开发参数配置全解 6大公共组件详解(点击进入): title详解. tooltip详解.toolb ...

  5. 用Python的Plotly画出炫酷的数据可视化(含各类图介绍,附代码)

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 我被狗咬了 在谈及数据可视化的时候,我们通常都会使用到matplo ...

  6. Python图表数据可视化Seaborn:1. 风格| 分布数据可视化-直方图| 密度图| 散点图

    conda  install seaborn  是安装到jupyter那个环境的 1. 整体风格设置 对图表整体颜色.比例等进行风格设置,包括颜色色板等调用系统风格进行数据可视化 set() / se ...

  7. Python Pandas 时间序列双轴折线图

    时间序列pv-gmv双轴折线图 import numpy as np import pandas as pd import matplotlib.pyplot as plt n = 12 date_s ...

  8. 基于matplotlib的数据可视化 - 饼状图pie

    绘制饼状图的基本语法 创建数组 x 的饼图,每个楔形的面积由 x / sum(x) 决定: 若 sum(x) < 1,则 x 数组不会被标准化,x 值即为楔形区域面积占比.注意,该种情况会出现 ...

  9. 基于matplotlib的数据可视化 - 三维曲面图gca

    1 语法 ax = plt.gca(projection='3d')ax.plot_surface(x,y,z,rstride=行步距,cstride=列步距,cmap=颜色映射) gca(**kwa ...

随机推荐

  1. unserialize():Error at offset 0 of 96 bytes是什么意思

    数据库有个列是数组序列化后存到数据库的,取出来得反序列化, php想要把数组保存到数据库里,有两种序列化方式,分别是: //php系统序列化 $b = serialize($a);    //序列化数 ...

  2. Spark Streaming数据限流简述

      Spark Streaming对实时数据流进行分析处理,源源不断的从数据源接收数据切割成一个个时间间隔进行处理:   流处理与批处理有明显区别,批处理中的数据有明显的边界.数据规模已知:而流处理数 ...

  3. 如何在Windows上开启Ping或者禁止PING

    方法1:命令行模式 进入服务器后 点击 开始——运行 输入命令: netsh firewall set icmpsetting 8 这样就可以在外部ping到服务器了 非常简单实用! 同样道理,如果想 ...

  4. java_HashMap的遍历方法_4种

    1.通过接收keySet来遍历: HashMap<String,String> map = new HashMap<>(); map.put("bb",&q ...

  5. Application Characteristics Of LED Keychain

    LED keychains are essential camping and travel accessories. Very useful as a light source. There are ...

  6. Eclipse中配置Tomcat容器

    Tomcat 安装与配置 Tomcat是Apache 软件基金会(Apache Software Foundation)核心项目之一,支持最新的Servlet 和JSP 规范.因为Tomcat 技术先 ...

  7. 转行小白成长路--java基础

    每天都会发一篇,一点一滴,记录在这条路上的足迹.立个flag 2019年3月份至今已近一年,对信息技术有个大概的了解,个人认为对于这门技术更应该从最底层的原理入手,了解计算机演化的历史,从计算机语言到 ...

  8. sencha Architect 3.2及以下版本都适用的 破解方法

    找到 没有的话 打开隐藏文件夹 C:\Users\ll\AppData\Local\Sencha\Sencha Architect 3.2 用编辑器 打开user.license 把 Print 修改 ...

  9. linux学习笔记1:无操作系统时LED驱动

  10. go语言 实现哈希算法

    验证结果网址 http://www.fileformat.info/tool/hash.htm "golang.org/x/crypto/md4"不存在时,解决方法: cd $GO ...