日期列为日期格式数据,绘图时会生成一系列连续的日期坐标点,并非date_range生成的那些,而且ticks参数是x州坐标下标数字数组,date_range话日期会转为数字显示出问题。
应该将日期列转字符串后,定义好x轴下标位置,在从数据源中截取对应的日期作为显示值,下面示例代码显示12个坐标
import pandas as pd
import matplotlib.pyplot as plt
import math
plt.rcParams['font.sans-serif']='SimHei'
data=pd.read_excel("data.xlsx")
data['日期']=data['日期'].apply(lambda x: x.strftime('%Y-%m-%d'))#转字符串
x2=data['日期']
y2=data['成交量']
plt.title('成交量柱状图')
plt.xlabel('日期')
plt.ylabel('成交量')
xnum=12#显示的点数量
rownum=len(x2)#总数据
step=math.ceil(rownum/xnum)
ticks=list(range(0,rownum,step))#坐标点数量及下标
labels=[x2[i] for i in range(len(x2)) if i%step==0 ]#获取对应的显示日期
plt.bar(x2,y2)
plt.xticks(ticks,labels)
plt.show()
xticks接受list数组,你生成的那个不是list数组
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!