如何将文本放在 matplotlib 图形的左上角(或右上角),例如左上角图例所在的位置,或者在图的顶部但在左上角?例如,如果它是 plt.scatter()
,那么将在散布的正方形内的东西放在最左上角。
例如,我想在理想情况下不知道所绘制散点图的比例的情况下执行此操作,因为它会从数据集更改为数据集。我只是希望它的文本大致在左上角,或者大致在右上角。使用图例类型定位时,无论如何它都不应与任何散点图点重叠。
您可以使用 text
。
text(x, y, s, fontsize=12)
text
坐标可以相对于轴给出,因此文本的位置将与绘图的大小无关:
默认转换指定文本在数据坐标中,或者,您可以在轴坐标中指定文本(0,0 是左下角,1,1 是右上角)。下面的示例将文本放置在轴的中心:
text(0.5, 0.5,'matplotlib',
horizontalalignment='center',
verticalalignment='center',
transform = ax.transAxes)
为了防止文本干扰你分散的任何点,afaik 更加困难。更简单的方法是将 y_axis(ylim((ymin,ymax))
中的 ymax)设置为比您的点的最大 y 坐标略高的值。这样,您将始终拥有用于文本的空闲空间。
编辑:这里有一个例子:
In [17]: from pylab import figure, text, scatter, show
In [18]: f = figure()
In [19]: ax = f.add_subplot(111)
In [20]: scatter([3,5,2,6,8],[5,3,2,1,5])
Out[20]: <matplotlib.collections.CircleCollection object at 0x0000000007439A90>
In [21]: text(0.1, 0.9,'matplotlib', ha='center', va='center', transform=ax.transAxes)
Out[21]: <matplotlib.text.Text object at 0x0000000007415B38>
In [22]:
https://i.stack.imgur.com/WJhW8.png
ha 和 va 参数设置文本相对于插入点的对齐方式。 IE。 ha='left' 是一个很好的设置,可以防止在手动缩小(变窄)框架时长文本超出左轴。
matplotlib 与发布原始答案时有些不同
matplotlib.pyplot.text
matplotlib.axes.Axes.text
这个答案与 seaborn 相关,它是 matplotlib 的高级 api。
在 python 3.10、matplotlib 3.5.1、seaborn 0.11.2 中测试
import matplotlib.pyplot as plt
plt.figure(figsize=(6, 6))
plt.text(0.1, 0.9, 'text', size=15, color='purple')
# or
fig, axe = plt.subplots(figsize=(6, 6))
axe.text(0.1, 0.9, 'text', size=15, color='purple')
两者的输出
https://i.stack.imgur.com/bhoS7.png
来自 matplotlib:精确的文本布局您可以在数据或轴坐标中精确地布局文本。
您可以在数据或坐标轴坐标中精确布局文本。
import matplotlib.pyplot as plt
# Build a rectangle in axes coords
left, width = .25, .5
bottom, height = .25, .5
right = left + width
top = bottom + height
ax = plt.gca()
p = plt.Rectangle((left, bottom), width, height, fill=False)
p.set_transform(ax.transAxes)
p.set_clip_on(False)
ax.add_patch(p)
ax.text(left, bottom, 'left top',
horizontalalignment='left',
verticalalignment='top',
transform=ax.transAxes)
ax.text(left, bottom, 'left bottom',
horizontalalignment='left',
verticalalignment='bottom',
transform=ax.transAxes)
ax.text(right, top, 'right bottom',
horizontalalignment='right',
verticalalignment='bottom',
transform=ax.transAxes)
ax.text(right, top, 'right top',
horizontalalignment='right',
verticalalignment='top',
transform=ax.transAxes)
ax.text(right, bottom, 'center top',
horizontalalignment='center',
verticalalignment='top',
transform=ax.transAxes)
ax.text(left, 0.5 * (bottom + top), 'right center',
horizontalalignment='right',
verticalalignment='center',
rotation='vertical',
transform=ax.transAxes)
ax.text(left, 0.5 * (bottom + top), 'left center',
horizontalalignment='left',
verticalalignment='center',
rotation='vertical',
transform=ax.transAxes)
ax.text(0.5 * (left + right), 0.5 * (bottom + top), 'middle',
horizontalalignment='center',
verticalalignment='center',
transform=ax.transAxes)
ax.text(right, 0.5 * (bottom + top), 'centered',
horizontalalignment='center',
verticalalignment='center',
rotation='vertical',
transform=ax.transAxes)
ax.text(left, top, 'rotated\nwith newlines',
horizontalalignment='center',
verticalalignment='center',
rotation=45,
transform=ax.transAxes)
plt.axis('off')
plt.show()
https://i.stack.imgur.com/mCOgW.png
seaborn轴水平图
import seaborn as sns
# sample dataframe
flights = sns.load_dataset("flights")
fig, axe = plt.subplots(figsize=(6, 6))
g = sns.lineplot(data=flights, x="year", y="passengers", ax=axe)
g.text(1950, 500, 'flights with CI', size=15, color='purple')
https://i.stack.imgur.com/nqFqe.png
seaborn 人物级情节
tips = sns.load_dataset('tips')
g = sns.relplot(data=tips, x="total_bill", y="tip", hue="day", col="time")
# iterate through each axes
for ax in g.axes.flat:
ax.text(10, 9, "Who's Hungy?", size=15, color='purple')
https://i.stack.imgur.com/Z5UwK.png
一种解决方案是使用 plt.legend
函数,即使您不需要实际的图例。您可以使用 loc
关键字指定图例框的位置。可以在 at this website 中找到更多信息,但我还提供了一个示例,说明如何放置图例:
ax.scatter(xa,ya, marker='o', s=20, c="lightgreen", alpha=0.9)
ax.scatter(xb,yb, marker='o', s=20, c="dodgerblue", alpha=0.9)
ax.scatter(xc,yc marker='o', s=20, c="firebrick", alpha=1.0)
ax.scatter(xd,xd,xd, marker='o', s=20, c="goldenrod", alpha=0.9)
line1 = Line2D(range(10), range(10), marker='o', color="goldenrod")
line2 = Line2D(range(10), range(10), marker='o',color="firebrick")
line3 = Line2D(range(10), range(10), marker='o',color="lightgreen")
line4 = Line2D(range(10), range(10), marker='o',color="dodgerblue")
plt.legend((line1,line2,line3, line4),('line1','line2', 'line3', 'line4'),numpoints=1, loc=2)
请注意,因为 loc=2
,所以图例位于图的左上角。如果文本与绘图重叠,您可以使用 legend.fontsize
将其缩小,这将使图例变小。