简体   繁体   English

Python 中的分组 X 轴变异图

[英]Grouped X-axis Variability plot in Python

I have a dataset as below.我有一个数据集如下。 I would like to plot a variability plot like in JMP with Grouped X-axis with multiple categories and legend by row.我想绘制一个变异图,如 JMP 中的分组 X 轴,具有多个类别和逐行图例。 Example of dataset and Plot from JMP are below. JMP 的数据集和绘图示例如下。 Is there a Pythonic solution to plotting this type of data?是否有绘制此类数据的 Pythonic 解决方案? I am looking for a solution using any of the python plotting libraries - bokeh,matplotlib,seaborn etc.,我正在寻找使用任何 python 绘图库的解决方案 - bokeh、matplotlib、seaborn 等,

样本数据

JMP 变量图示例

You can try this code, you'll need to modify the xlim and ylim parameters of plot to fit your real data:你可以试试这个代码,你需要修改xlimylim参数以适合你的真实数据:

import pandas as pd
import matplotlib.pyplot as plt
from itertools import groupby
import numpy as np 
%matplotlib inline

df = pd.DataFrame({'Name':['John']*2+['David']*2+['Mike']*2+['Albert']*2+['King']*2+['Brown']*2,
                  'TEST_Name':['Class A']*6+['Class B']*6,
                  'Label':['Median','NINETYFIVEPERC']*6,
                  'Data':[.54,.62,.55,.62,.55,.67,.58,1.05,.54,.60,.54,.60]})
df = df.set_index(['TEST_Name','Name','Label'])['Data'].unstack()

def add_line(ax, xpos, ypos):
    line = plt.Line2D([xpos, xpos], [ypos + .1, ypos],
                      transform=ax.transAxes, color='gray')
    line.set_clip_on(False)
    ax.add_line(line)

def label_len(my_index,level):
    labels = my_index.get_level_values(level)
    return [(k, sum(1 for i in g)) for k,g in groupby(labels)]

def label_group_bar_table(ax, df):
    ypos = -.1
    scale = 1./df.index.size
    for level in range(df.index.nlevels)[::-1]:
        pos = 0
        for label, rpos in label_len(df.index,level):
            lxpos = (pos + .5 * rpos)*scale
            ax.text(lxpos, ypos, label, ha='center', transform=ax.transAxes)
            add_line(ax, pos*scale, ypos)
            pos += rpos
        add_line(ax, pos*scale , ypos)
        ypos -= .1

ax = df.plot(marker='o', linestyle='none', xlim=(-.5,5.5), ylim=(.3,1.1))
#Below 2 lines remove default labels
ax.set_xticklabels('')
ax.set_xlabel('')
label_group_bar_table(ax, df)
# you may need these lines, if not working interactive
# plt.tight_layout()
# plt.show()

Output Chart:输出图表:

在此处输入图片说明

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM