空间转录组学数据处理只依赖R语言?让我们从scanpy开始,拥抱python吧!

学术   2024-11-04 19:01   上海  

前言
空间转录组学分析,是近几年的一个热点。相信小伙伴们对于seurat再熟悉不过了!但是seurat是基于R语言生态来进行数据处理的,数据处理起来实在是太麻烦了!Python在图像识别、空间分割和去卷积等算法领域拥有绝对的优势!Scanpy是基于python的单细胞分析工具包,江湖地位相当于R语言中的seurat。重要程度不用我多说了吧!没接触过python的小伙伴们也不要害怕哦!它与seurat的分析流程基本一致,都是质控-选择高变基因-PCA降维-聚类-UMAP(tSNE)降维这些步骤。没有时间学习的小伙伴们也不要着急哦!有需要生信分析的小伙伴们也可以找果叔哦!练了十年生信分析的果叔对于生信分析知识已经如鱼得水从分析到可视化直到你满意为止!

跑代码时卡顿、电脑不给力让人抓狂!找果叔试用稳定高速的服务器,让分析顺畅无比!

代码学不会?bug 频繁出现,束手无策?实操生信分析课程赶快学起来!滴滴果叔领取体验课程哦~


线上课程教学

课题设计、定制生信分析

云服务器租赁

加微信备注99领取使用


代码教程
1.导入相关的库
import scanpy as scimport pandas as pdimport matplotlib.pyplot as pltimport seaborn as snssc.logging.print_versions()    sc.set_figure_params(facecolor="white", figsize=(8, 8))sc.settings.verbosity = 3      
2.读取数据
我们将使用人类淋巴结的 Visium 空间转录组学数据集。函数 datasets.visium_sge() 从 10x Genomics 下载数据集并返回一个包含计数、图像和空间坐标的对象。使用您自己的 Visium 数据时,请使用 sc.read_visium() 函数导入它。         

 

adata = sc.datasets.visium_sge(sample_id="V1_Human_Lymph_Node")adata.var_names_make_unique()adata.var["mt"] = adata.var_names.str.startswith("MT-")sc.pp.calculate_qc_metrics(adata, qc_vars=["mt"], inplace=True)adata         
3. 质量控制和预处理
我们根据总数和表达基因对样本进行一些基本的过滤
fig, axs = plt.subplots(1, 4, figsize=(15, 4))sns.histplot(adata.obs["total_counts"], kde=False, ax=axs[0])sns.histplot(    adata.obs["total_counts"][adata.obs["total_counts"] < 10000],    kde=False,    bins=40,        ax=axs[1],)sns.histplot(adata.obs["n_genes_by_counts"], kde=False, bins=60, ax=axs[2])sns.histplot(    adata.obs["n_genes_by_counts"][adata.obs["n_genes_by_counts"] < 4000],    kde=False,    bins=60,    ax=axs[3],)
         

 

sc.pp.filter_cells(adata, min_counts=5000)sc.pp.filter_cells(adata, max_counts=35000)adata = adata[adata.obs["pct_counts_mt"] < 20].copy()print(f"#cells after MT filter: {adata.n_obs}")sc.pp.filter_genes(adata, min_cells=10)
         

 

   
我们继续使用 Scanpy 的内置方法对 Visium 计数数据进行归一化,并检测高度可变的基因
sc.pp.normalize_total(adata, inplace=True)sc.pp.log1p(adata)sc.pp.highly_variable_genes(adata, flavor="seurat", n_top_genes=2000)
         

 

4. 基于转录相似性的流形嵌入和聚类
sc.pp.pca(adata)sc.pp.neighbors(adata)sc.tl.umap(adata)sc.tl.leiden(    adata, key_added="clusters", flavor="igraph", directed=False, n_iterations=2)
我们绘制了一些协变量,以检查 UMAP 中是否存在与总数和检测到的基因相关的任何特定结构。
plt.rcParams["figure.figsize"] = (4, 4)sc.pl.umap(adata, color=["total_counts", "n_genes_by_counts", "clusters"], wspace=0.4)
   
5. 空间坐标中的可视化
plt.rcParams["figure.figsize"] = (8, 8)sc.pl.spatial(adata, img_key="hires", color=["total_counts", "n_genes_by_counts"])
         

 

函数 sc.pl.spatial 接受 4 个附加参数:
limg_key:其中 IMG 存储在元素中adata.uns
lcrop_coord:用于裁剪的坐标(左、右、上、下)
lalpha_img:图像透明度的 alpha 值
lbw:标志将图像转换为灰度
之前,我们在基因表达空间中进行了聚类,并用UMAP可视化了结果。通过在空间维度上可视化聚类样本,我们可以深入了解组织组织,并可能深入了解细胞间通讯。    
sc.pl.spatial(adata, img_key="hires", color="clusters", size=1.5)
基因表达空间中属于同一簇的斑点通常在空间维度上共现。例如,属于聚类 5 的斑点通常被属于聚类 0 的点包围。
我们可以放大特定的感兴趣区域以获得定性见解。此外,通过改变斑点的 alpha 值,我们可以从 H&E 图像中更好地可视化下面的组织形态。
sc.pl.spatial(    adata,    img_key="hires",        color="clusters",    groups=["5", "9"],    crop_coord=[7000, 10000, 0, 6000],    alpha=0.5,    size=1.3,)
6. 亚群标记基因    
计算标记基因并绘制热图,其中前 10 个标记基因的表达水平。
sc.tl.rank_genes_groups(adata, "clusters", method="t-test")sc.pl.rank_genes_groups_heatmap(adata, groups="9", n_genes=10, groupby="clusters")
 
##我们看到 CR2 概括了空间结构。sc.pl.spatial(adata, img_key="hires", color=["clusters", "CR2"])
   
sc.pl.spatial(adata, img_key="hires", color=["COL1A2", "SYPL1"], alpha=0.7)
7. MERFISH示例
如果您使用基于 FISH 的技术生成空间数据,只需阅读 cordinate 表并将其分配给元素即可。
# If needed:# %pip install openpyxlcoordinates = pd.read_excel("./data/pnas.1912459116.sd15.xlsx", index_col=0)counts = sc.read_csv("./data/pnas.1912459116.sd12.csv").transpose()    adata_merfish = counts[coordinates.index, :].copy()adata_merfish.obsm["spatial"] = coordinates.to_numpy()           #预处理和降维sc.pp.normalize_per_cell(adata_merfish, counts_per_cell_after=1e6)sc.pp.log1p(adata_merfish)sc.pp.pca(adata_merfish, n_comps=15)sc.pp.neighbors(adata_merfish)sc.tl.umap(adata_merfish)sc.tl.leiden(    adata_merfish,    key_added="clusters",    resolution=0.5,    n_iterations=2,    flavor="igraph",    directed=False,)adata_merfishsc.pl.umap(adata_merfish, color="clusters")sc.pl.embedding(adata_merfish, basis="spatial", color="clusters")
   
         

 

   
         

 

小结
好啦,今天的分享结束啦!Scanpy是与seurat的分析流程基本一致,都是质控-选择高变基因-PCA降维-聚类-UMAP(tSNE)降维这些步骤。但是,Python相比R有更好的内存管理,更丰富的人工智能算法资源,并且可以调用GPU加速计算。Python在图像识别、空间分割和去卷积等算法领域拥有更好的资源,因此很多优秀的空转分析工具都是python编写的。做好空转数据的分析不能局限于R语言生态,让我们从scanpy开始,拥抱python。最后果叔给大家介绍一个云工具!同学们如果觉得自己的代码水平一般,对于很多的参数不知道怎么改,可以体验一下我们的云生信小工具,只需输入数据,即可轻松生成所需图表,字体大小、标题等也可一键更改。感兴趣的小伙伴去云生信(http://www.biocloudservice.com/home.html)体验一下吧!

不会分析还想用生信工具助力发文咋办?有这顾虑的朋友,想一步到位就带着想法来,不论是代码实操还是在线文章结果复现,果叔照样能提供,还有大家都想要的服务器,找果叔获取就对了!

往期回顾

01

厉害了,我的宝!哈医大本科生一作,0实验收下5分+纯生信!这波属实“信”福来敲门,被这操作狠狠秀到!

02

发了N篇一区SCI后,目前看来,这种方法是最容易“水”TOP文章的!发不发的出去,全看你的选题如何!

03

纯生信47天冲进Q1区7.7分!这才是当下极品毕业神刊!分析方法全是老“套路”,出奇制胜就因为选题牛!

04

熬夜=爆肝被实锤了!最新研究:失眠打鼾缺觉党,“困” 境重重小心脂肪肝风险 “爆” 表!UKB+两步MR+中介分析,深度剖析!



生信果
生信入门、R语言、生信图解读与绘制、软件操作、代码复现、生信硬核知识技能、服务器等
 最新文章