所以我试图在我的python网络应用中显示一些分析数据。我想在x轴上显示第一个和最后一个条目的日期时间。
我试图将刻度线设置为两个条目列表,但结果却很糟糕。
plt.scatter(x_data, y_data)
plt.grid(True)
plt.xticks(x_data, [x_data[0], x_data[-1]])
fig = plt.gcf()
x_data在哪里
['10:59:44 27-03-2019', '11:00:07 27-03-2019', '11:00:09 27-03-2019', '11:00:12 27-03-2019', '11:30:23 27-03-2019', '11:30:29 27-03-2019', '11:30:30 27-03-2019', '11:30:31 27-03-2019', '11:30:32 27-03-2019', '11:32:44 27-03-2019', '11:33:21 27-03-2019', '11:35:50 27-03-2019', '12:16:12 27-03-2019', '12:16:39 27-03-2019', '12:17:36 27-03-2019', '12:19:40 27-03-2019', '12:23:50 27-03-2019']
我希望输出将一个放在最左边,另一个放在最右边。相反,前两个滴答只是显示时间重叠。
我不确定该怎么做。
答案 0 :(得分:2)
这是使用一些随机数据的解决方法,因为您没有指定y_data
是什么。这个想法是循环浏览现有的默认刻度标签,然后用空字符串替换所有刻度标签,除了第一个和最后一个。
fig, ax = plt.subplots()
plt.scatter(x_data, range(len(x_data)))
plt.grid(True)
fig.canvas.draw()
xticks = ax.get_xticklabels()
labels_new = [lab.get_text() if i in [0, len(xticks)-1] else ""
for i, lab in enumerate(xticks) ]
ax.set_xticklabels(labels_new)
plt.show()
答案 1 :(得分:1)
我怀疑您的问题是,您正在定义刻度线向量,然后分配两个标签(位置0和1)。
import numpy as np
import matplotlib.pyplot as plt
x_data=np.array([1,2,3,4,5,6,7,8])
y_data=np.random.normal(0, 1, (8, 1))
# create an array for your labels
new_labels=[''] * (len(x_data)-2)
new_labels.insert(0,x_data[0])
new_labels.append(x_data[-1])
plt.scatter(x_data, y_data)
plt.grid(True)
plt.xticks(x_data, new_labels) #use the new tick labels
fig = plt.gcf()