千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > python如何画火山图

python如何画火山图

来源:千锋教育
发布人:xqq
时间: 2023-11-13 13:45:15 1699854315

python中如何画火山图

1、导入数据

importpandasaspd#Dataanalysis

importnumpyasnp#Scientificcomputing

importseabornassns#Statisticalvisualization

#读取数据

df=pd.read_csv('./dataset_volcano.txt',sep='\t')

result=pd.DataFrame()

result['x']=df['logFC']

result['y']=df['P.Value']

result['-log10(pvalue)']=-df['P.Value'].apply(np.log10)

2、设置阈值

#设置pvalue和logFC的阈值

cut_off_pvalue=0.0000001

cut_off_logFC=1

3、设置分组

#分组为up,normal,down

result.loc[(result.x>cut_off_logFC)&(result.y

result.loc[(result.x<-cut_off_logFC)&(result.y

result.loc[(result.x>=-cut_off_logFC)&(result.x<=cut_off_logFC)|(result.y>=cut_off_pvalue),'group']='normal'

4、绘制散点图

#绘制散点图

ax=sns.scatterplot(x="x",y="-log10(pvalue)",

hue='group',

hue_order=('down','normal','up'),

palette=("#377EB8","grey","#E41A1C"),

alpha=0.5,

s=15,

5、设置散点图

#确定坐标轴显示范围

xmin=-6

xmax=10

ymin=7

ymax=13

ax.spines['right'].set_visible(False)#去掉右边框

ax.spines['top'].set_visible(False)#去掉上边框

ax.vlines(-cut_off_logFC,ymin,ymax,color='dimgrey',linestyle='dashed',linewidth=1)#画竖直线

ax.vlines(cut_off_logFC,ymin,ymax,color='dimgrey',linestyle='dashed',linewidth=1)#画竖直线

ax.hlines(-np.log10(cut_off_pvalue),xmin,xmax,color='dimgrey',linestyle='dashed',linewidth=1)#画竖水平线

ax.set_xticks(range(xmin,xmax,4))#设置x轴刻度

ax.set_yticks(range(ymin,ymax,2))#设置y轴刻度

ax.set_ylabel('-log10(pvalue)',fontweight='bold')#设置y轴标签

ax.set_xlabel('log2(foldchange)',fontweight='bold')#设置x轴标签

以上就是python中画火山图的方法,希望能对大家有所帮助,更多Python学习教程请关注IT培训机构:千锋教育。

tags: python培训
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT