Python生物信息学③提取差异基因

举报
DrugAI 发表于 2021/07/15 05:30:49 2021/07/15
【摘要】 python做生信分析的流程 使用的数据集是GSE5583,来自于2006年的基因芯片结果,该芯片目的是提取野生型和HDAC1小鼠胚胎干细胞用于Affymetrix微阵列上的差异RNA。 #导入包import matplotlib.pyplot as pltimport osimport numpy as npimport pandas as pdfrom scipy i...

python做生信分析的流程

使用的数据集是GSE5583,来自于2006年的基因芯片结果,该芯片目的是提取野生型和HDAC1小鼠胚胎干细胞用于Affymetrix微阵列上的差异RNA。


  
  1. #导入包
  2. import matplotlib.pyplot as plt
  3. import os
  4. import numpy as np
  5. import pandas as pd
  6. from scipy import stats
  7. import seaborn as sns
  8. %matplotlib inline

  
  1. #载入数据
  2. data = pd.read_table("GSE5583.txt",header = 0,index_col = 0)
  3. data.head() #查看前5行

每一行是一个基因,每一列是一个样本,这也是比较经典的芯片数据集


  
  1. #查看数据维度
  2. data.shape

标准化

常见的log2()标准化


  
  1. data2 = np.log2(data+0.0001)
  2. data2.head()


  
  1. # 每个阵列的箱线图
  2. plt.show(data2.plot(kind = 'box', title = 'GSE5583 Boxplot', rot = 90))

目的是查看不同样本之间是否有总体差异。


  
  1. # Density
  2. plt.show(data2.plot(kind = 'density', title = 'GSE5583 Density'))

可以看出样本之间没有总体差异,可以做差异分析。


  
  1. #每个基因(行)wt样本的表达平均值
  2. wt = data2.loc[:, 'WT.GSM130365' : 'WT.GSM130367'].mean(axis = 1)
  3. wt.head()

  
  1. #每个基因(行)的ko样本的表达平均值
  2. ko = data2.loc[:,'KO.GSM130368':'KO.GSM130370'].mean(axis = 1)
  3. ko.head()

  
  1. fold = ko - wt
  2. #折叠变化的直方图
  3. plt.hist(fold)
  4. plt.title("Histogram of fold-change")
  5. plt.show()

查看基因差异的P值分布


  
  1. from scipy import stats
  2. pvalue = []
  3. for i in range(0, number_of_genes):
  4. ttest = stats.ttest_ind(data2.iloc[i,0:3], data2.iloc[i,3:6])
  5. pvalue.append(ttest[1])
  6. # Histogram of the p-values
  7. plt.hist(-np.log(pvalue))
  8. plt.title("Histogram of p-value")
  9. plt.show()


参考:

https://www.jianshu.com/p/91c98585b79b

 

文章来源: drugai.blog.csdn.net,作者:DrugAI,版权归原作者所有,如需转载,请联系作者。

原文链接:drugai.blog.csdn.net/article/details/88877273

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。