python - 如何使用 matplotlib 绘制汇总的时间序列数据
问题描述
我有一个错误的 csv 文件,其中包含每个错误发生时间的时间戳。示例数据如下所示
2020-01-06T02:54:01.012+0000, 500 Internal Server Error
2020-01-06T05:04:01.012+0000, 500 Internal Server Error
2020-01-06T05:44:01.012+0000, 500 Internal Server Error
2020-01-06T07:04:01.013+0000, 500 Internal Server Error
2020-01-06T08:04:01.012+0000, 500 Internal Server Error
2020-01-06T10:24:01.010+0000, 500 Internal Server Error
2020-01-06T17:48:31.192+0000, 503 Service Unavailable
2020-01-08T04:35:48.624+0000, 502 Bad Gateway
2020-01-08T16:56:04.814+0000, 503 Service Unavailable
我想使用 matplotlib 将每分钟(或 30 秒)的错误显示为图表上的单独一行。不知道怎么做聚合?这是我尝试过的。有什么帮助吗?
import matplotlib.pyplot as plt
import pandas as pd
infile="example.csv"
dateparse = lambda time_str: pd.datetime.strptime(time_str, '%Y-%m-%dT%H:%M:%S.%f')
df = pd.read_csv(infile, parse_dates=['datetime'], date_parser=dateparse, index_col="datetime", names=['datetime','error'])
df.plot()
plt.show()
解决方案
从定义以下函数开始:
def counts(grp):
codeList = ['500', '502', '503']
return pd.Series([np.count_nonzero(grp.eq(code)) for code in codeList],
index=map(lambda x: 'Err_' + x, codeList))
它将很快应用到由重新采样 DataFrame 产生的每个组。
按如下方式阅读您的文件:
df = pd.read_csv('your_log.csv', names=['Date', 'Message'],
skipinitialspace=True, parse_dates=[0])
注意skipinitialspace参数,需要在每个逗号之后(日期/时间之后)去除初始空间。
然后运行:从结果df.Date = df.Date.dt.tz_localize(None)
中删除时区部分(+0000)。
由于比较完整字符串很尴尬,我决定只比较错误代码(每条消息的 3 个初始字符)。为此,让我们创建一个仅包含错误代码的新列:
df['Code'] = df.Message.str.slice(0,3)
下一步它通过重新采样并将上述函数应用于每个小时组来生成每小时的错误数量:
errCnt = df.resample('1H', on='Date').Code.apply(counts).unstack(level=1)
如果您想要任何其他时间分辨率,请将1H更改为所需的时间段。
最后一步是添加Total列(如果需要):
errCnt['Total'] = errCnt.sum(axis=1)
对于我的示例数据(有更多错误,在更短的时间内),我得到:
Err_500 Err_502 Err_503 Total
Date
2020-01-06 02:00:00 1 0 0 1
2020-01-06 03:00:00 0 0 0 0
2020-01-06 04:00:00 0 0 0 0
2020-01-06 05:00:00 1 2 2 5
2020-01-06 06:00:00 0 0 0 0
2020-01-06 07:00:00 1 0 0 1
2020-01-06 08:00:00 1 0 0 1
推荐阅读
- php - 如何在 WooCommerce 产品循环中显示添加到购物车的通知
- vbscript - 正则表达式检查时需要消除不必要的重复文件
- rust - 将项目设置为默认使用 nightly
- java - 是否可以在不重新启动服务器的情况下在远程 weblogic 上重新部署应用程序?
- laravel - Laravel 缓存忘记记住永远缓存不起作用?
- signal-processing - LabVIEW中正弦波信号的峰峰值幅度随时间的变化
- r - 如何在R中使用knitr :: kables并排居中?
- android - android中的时间格式
- python - 将 collections.Counters 的组合频率从数据帧多索引转换为字符串
- javascript - 当标记超出指定区域时收到警报(Google Maps API)