gpt4 book ai didi

python - 添加数据透视表列和索引作为 xticks 和 yticks

转载 作者:太空宇宙 更新时间:2023-11-03 21:23:36 25 4
gpt4 key购买 nike

我有一个根据此创建的数据透视表:Color mapping of data on a date vs time plot并用 imshow() 绘制它。我想使用数据透视表的索引和列作为 yticks 和 xticks。我的数据透视表中的列是日期,索引是一天中的时间。

data = pd.DataFrame()
data['Date']=Tgrad_GFAVD_3m2mRot.index.date
data['Time']=Tgrad_GFAVD_3m2mRot.index.strftime("%H")
data['Tgrad']=Tgrad_GFAVD_3m2mRot.values

C = data.pivot(index='Time', columns='Date', values='Tgrad')

print(C.head()):

Date 2016-08-01 2016-08-02 2016-08-03 2016-08-04 2016-08-05 2016-08-06 \
Time
00 -0.841203 -0.541871 -0.042984 -0.867929 -0.790869 -0.940757
01 -0.629176 -0.520935 -0.194655 -0.866815 -0.794878 -0.910690
02 -0.623608 -0.268820 -0.255457 -0.859688 -0.824276 -0.913808
03 -0.615145 -0.008241 -0.463920 -0.909354 -0.811136 -0.878619
04 -0.726949 -0.169488 -0.529621 -0.897773 -0.833408 -0.825612

我用绘制数据透视表

fig, ax = plt.subplots(figsize = (16,9))
plt = ax.imshow(C,aspect = 'auto', extent=[0,len(data["Date"]),0,23], origin = "lower")

我尝试了一些方法,但没有任何效果。目前我的xticks范围在0到6552之间,这是C.columns对象的长度,由imshow()中的extent参数设置

我希望在每个月的第一天都有 xticks,但不是按索引号,而是作为格式为“2016-08-01”的日期标记。

我确信过去一个小时里这只是一件小事阻碍了我,但现在我放弃了。你知道如何相应地设置 xticks 吗?

最佳答案

在尝试了另一件事后,我自己找到了解决方案。我在“数据”数据框中创建了另一列,其中包含日期数字条目而不是日期

data["datenum"]=mdates.date2num(data["Date"])

然后将剧情线更改为:

pl = ax.imshow(C,aspect = 'auto',
extent=[data["datenum"].iloc[0],data["datenum"].iloc[-1],data["Time"].iloc[0],data["Time"].iloc[-1]],
origin = "lower")

因此,范围参数的更改为绘图提供了日期数值,而不是日期列的索引。然后,以下几行就起作用了:

ax.set_yticks(data["Time"]) # sets yticks
ax.xaxis_date() # tells the xaxis that it should expect datetime values
ax.xaxis.set_major_formatter(mdates.DateFormatter("%m/%d") ) # formats the datetime values
fig.autofmt_xdate() # makes it look nice

最好,沃尼

关于python - 添加数据透视表列和索引作为 xticks 和 yticks,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54027447/

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