官网地址: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. 《图解HTTP》笔记

    web网络基础 概述 Web是建立在HTTP(超文本传输协议)上通信的 通常使用的网络(包括互联网)是在TCP/IP基础上运作的,HTTP属于它的内部子集 TCP/IP协议 协议族 计算机与网络设备要 ...

  2. sqlalchemy_mptt一次调优

    问题背景: 我用sqlalchemy_mptt构建了一个多级分类项目,数据库用了sqlite.随着数据条数越来越多,写入速度逐渐变慢,一棵树的插入甚至需要1分钟,远远不能满足需求 分析思路: 1. 批 ...

  3. C++-POJ3070-Fibonacci-[矩阵乘法][快速幂]

    #include <cstdio> ][];}; ,MOD=1e4; Matrix A,B,O,I; Matrix Mul(Matrix A,Matrix B){ Matrix C=O; ...

  4. 使用pycharm搜索框和正则表达式匹配内容

    使用pycharm搜索框和正则表达式匹配内容原创薯饼__ 最后发布于2019-03-04 19:28:53 阅读数 660 收藏展开有时候我们要在爬虫网站中匹配各种各样的文本块,以获取需要的信息,每一 ...

  5. Codeforces Round #623 (Div. 2) D.Recommendations 并查集

    ABC实在是没什么好说的,但是D题真的太妙了,详细的说一下吧 首先思路是对于a相等的分类,假设有n个,则肯定要把n-1个都增加,因为a都是相等的,所以肯定是增加t小的分类,也就是说每次都能处理一个分类 ...

  6. 斜率优化 DP

    CF311B Cats Transport 暑假到现在终于过了这道题

  7. 立即关机C++源码

    #include<windows.h> using namespace std; int main(){ system("shutdown /p"); return 0 ...

  8. Xlrd模块读取Excel文件数据

    Xlrd模块使用 excel文件样例:

  9. eclipse怎么debug项目

    1.打断点,服务器debug启动 2.debug:打断点,加项目.f5:进入方法    f6:下一行代码   f8:执行到下一个断点处

  10. FormData控制台打印为空及使用方法

    之前使用formData都是在network中查看参数,最近在做一个项目,接口还没有,用的假数据做的交互,突发奇想的console.log了 一下,结果是空的. 一开始以为append失效了,经过查证 ...