我为此问题创建了一个示例数据集
import pandas as pd
from pandas import DataFrame
import seaborn as sns
import numpy as np
sex = np.array(['Male','Female'])
marker1 = np.array(['Absent','Present'])
marker2 = np.array(['Absent','Present'])
sample1 = np.random.randint(0,2,100)
sample2 = np.random.randint(0,2,100)
sample3 = np.random.randint(0,2,100)
df=pd.concat([pd.Series(sex.take(sample1),dtype='category'),pd.Series(marker1.take(sample2),dtype='category'),pd.Series(marker2.take(sample3),dtype='category')],axis=1)
df.rename(columns={0:'Sex',1:'Marker1',2:'Marker2'},inplace=True)
fig =sns.FacetGrid(data=df,col='Sex',hue='Marker2',palette='Set1',size=4,aspect=1).map(sns.countplot,'Marker1',order=df.Marker1.unique()).add_legend()
此代码创建的图是堆积图 here 我想要创建的是一个躲闪情节(来自R)。如何修改此代码,以便我可以看到 Marker2 存在的并排比较?
答案 0 :(得分:3)
我遇到了同样的问题,这对我有用。
您可以为sns.countplot
调用编写一个包装函数,以使用FacetGrid命令。
def countplot(x, hue, **kwargs):
sns.countplot(x=x, hue=hue, **kwargs)
grid = sns.FacetGrid(data=df,col='Sex',size=4,aspect=1)
fig = grid.map(countplot,'Marker1','Marker2',palette='Set1',order=df.Marker1.unique())
fig.add_legend()