python如何画火山图
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培训机构:千锋教育。
猜你喜欢LIKE
相关推荐HOT
更多>>Python中使用K-means算法
python中使用K-means算法k-means是机器学习中最常用的聚类算法,关于k-means算法的数学原理、算法、伪码等已有相当丰富的文献,在此不再赘述。1...详情>>
2023-11-14 22:27:42python包和模块的内容整理
python包和模块的内容整理1、包(1)包是一个文件夹,存放多个模块,作用是包含多个模块,本质上仍然是模块,因此包也可以包含在其中。(2)库:与...详情>>
2023-11-14 21:31:01python线程中deque如何使用?
python线程中deque如何使用?1、说明collections.deque类是一种线程安全的数据类型,可以从两端快速添加或删除元素。而且如果你想有一个数据类型...详情>>
2023-11-14 18:22:54python并集是什么意思?
python并集是什么意思?本文教程操作环境:windows7系统、Python3.9.1,DELLG3电脑。以属于A或属于B的元素为元素的集合成为A与B的并集。1、概念...详情>>
2023-11-14 16:44:05热门推荐
python中如何实现列表与字典的相互转换?
沸python sorted中key参数怎么用?
热python中exec()函数如何执行表达式?
热Python中使用K-means算法
新python如何对电脑进行清屏
python包和模块的内容整理
python中scipy.special模块如何使用?
python检测给定的路径是否存在的方法
怎样在python中定义非闭包
python如何画火山图
pythonpickle模块的使用注意
python线程中deque如何使用?
python如何安装pyenv
pythontime模块的时间格式