gpt4 book ai didi

python-3.x - 如何在 Pandas 中将时间绘制为 x 轴

转载 作者:行者123 更新时间:2023-12-03 18:31:45 25 4
gpt4 key购买 nike

我正在尝试在 Pandas 中绘制一个数据框。我使用的 csv 文件是:

Time,Total cpu%,Used mem(k),Cache mem(k),Net mem Used%,Total mem Used%,Swap mem(%),process1 cpu%,process1 mem%,
4:19:25,12.5,885324,1249960,38.38,38.38,0,6.2,34.7
4:19:28,0.4,885460,1249804,38.39,38.39,0,5.3,34.7
4:19:31,1.8,885700,1249528,38.4,38.4,0,5,34.7
4:19:34,0.7,885700,1249528,38.4,38.4,0,5.3,34.7
4:19:37,0.4,885708,1249528,38.4,38.4,0,5.3,34.7
4:19:40,2.1,885704,1249528,38.4,38.4,0,5.3,34.7
4:19:43,0.4,885704,1249528,38.4,38.4,0,5,34.7
4:19:47,0.7,885700,1249528,38.4,38.4,0,5.3,34.7
4:19:50,13.8,885704,1249528,38.4,38.4,0,16,34.7

到目前为止我的代码是:
import pandas as pd
import matplotlib.pyplot as plt

# create dataframe
df = pd.read_csv('sample_csv.csv')

# select only cpu columns
cpu_columns = ['Total cpu%', 'process1 cpu%']

# dataframe from cpu columns
df1 = df[cpu_columns]

我想用 X 轴上的所有时间值绘制这个数据框。
所以我从“时间”列中的值创建了一个列表,并将其设置为 x_axis 值,如下所示:
x_axis = df["Time"].values

# plot dataframe
df1.plot(x=df["Time"])
plt.show()

以下是我到目前为止可以得到的图表:
cpu usage graph

所以X轴的标签显示为“时间”。如何在 X 轴的“时间”列中显示时间值?

最佳答案

您的问题似乎与您的时间存储方式有关。如果它们是 timedatetime dtypes 那么以下内容应该很适合您。

将时间设置为索引并简单地调用 plot。 Pandas 默认将索引设置为 x 轴。

df.Time = df.Time.dt.time
df.set_index('Time').plot()

但是,从您的代码的外观来看,它们并非如此。我们可以先将这些作为日期时间传递,然后将它们转换为时间(如果需要)。这可以使用 pd.to_datetime 来完成如下,
df.Time = pd.to_datetime(df.Time).dt.time
df.set_index('Time').plot()

备注 :这将默认使用今天的日期添加到日期时间。但是,当转换为 Time dtype 时,它​​会被删除。

关于python-3.x - 如何在 Pandas 中将时间绘制为 x 轴,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51556953/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com