在yticks位置绘制表格

凯文

我一直在尝试寻找一种以表格形式显示3元素列表的方法而遇到麻烦。我真正关心的是绘制表格。我想为图中的每个ylabel绘制一个1by3表。

以下是我到目前为止的内容。如果我可以显示每个Table实例,那么我将拥有所需的内容。现在出现了对表的引用,但我不确定为什么。如果您实际上是在参考位置出现的左中角,则可以看到一张1by3表格。

是否可以使用matplotlib为每个ylabel生成一个新表?表格信息与条形图中的每一行都直接相关,因此,重要的是我要有一种将它们对齐的方式。

条形图中的行数是动态的,因此要为整个图形创建1个表,并尝试使行与相应的条形图动态对齐是一个难题。

    # initialize figure
    fig = plt.figure()
    gs = gridspec.GridSpec(1, 2, width_ratios=[2, 1])
    fig.set_size_inches(18.5, 10.5)
    ax = fig.add_subplot(gs[0])

    #excluded bar graph code

    # create ylabels
    for row in range(1,len(data)):
        ylabel = [str(data[row][0]),str(data[row][1]),str(data[row][2])]
        ylabels.append(ylabel)

    #attempting to put each ylabel in a 1by3 table to display
    pos = np.arange(0.5,10.5,0.5)
    axTables = [None] * len(ylabels)
    for x in range(0,len(ylabels)):
        axTables[x] = fig.add_subplot(gs[0])
        ylabels[x] = axTables[x].table(cellText=[ylabels[x]], loc='left')

locsy, labelsy = plt.yticks(pos,ylabels)

在此处输入图片说明

认真的重要性

首先,yticks将期望文本作为输入,它将无法处理其他对象。其次,桌子需要坐在一个轴内。

因此,为了在tick(label)位置获得表,可以在ay ticklabel位置创建轴一个选项是使用mpl_toolkits.axes_grid1.inset_locator.inset_axes现在的困难是该轴需要沿着y轴放置在数据坐标中,并且在图形(或像素)中沿水平方向对齐。为此,可以使用混合变换。inset_axes允许给予的宽度和高度作为绝对测量(英寸)或相对的,这是很方便,因为我们可以设置轴边界框的100%的宽度,而高度还是有些绝对值(我们不不想让轴的高度取决于数据坐标!)。在下面的函数中ax_at_posy创建了这样的轴。

然后,桌子将紧紧地位于轴内,以使所有列的宽度相同。仍然需要确保始终使用相同的字体大小。

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.axes_grid1.inset_locator import inset_axes
import matplotlib.transforms as mtrans

# General helper function to create an axes at the position of a yticklabel
def ax_at_posy(y, ax=None, width=0.3, leftspace=0.08, height=0.2):
    ax = ax or plt.gca()
    trans = mtrans.blended_transform_factory(ax.figure.transFigure, ax.transData)
    axins = inset_axes(ax, "100%", height, 
                       bbox_to_anchor=(leftspace, y, width-leftspace, 0.05),
                       bbox_transform=trans, loc="center right", borderpad=0.8)
    axins.tick_params(left=False, bottom=False, labelleft=False, labelbottom=False)
    axins.axis("off")
    return axins


fig, ax = plt.subplots()
fig.subplots_adjust(left=0.4)

ax.scatter(np.random.rand(30), np.random.randint(7, size=30), c=np.random.rand(30))

get_data = lambda i: "".join(np.random.choice(list("abcdefgxyzt0"), size=i+2))
data = np.vectorize(get_data)(np.random.randint(2,6,size=(7,3)))

for i, row in enumerate(data):
    axi = ax_at_posy(i, ax=ax, width=0.4)
    tab = axi.table(cellText=[list(row)], loc='center', bbox=(0,0,1,1))
    tab.auto_set_font_size(False)
    tab.set_fontsize(9)
    plt.setp(tab.get_celld().values(), linewidth=0.72)

plt.show()

在此处输入图片说明

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章