scRNAseq:h5文件转化为matrix表达矩阵

前言

  今天想跟大家分享一下单细胞分析中的一个需求,就是如何将h5的表达量文件转化为常见的表达矩阵。大部分情况下,我们是不需要用到这个需求,因为通常我们见到的表达量文件是下面这三个文件:barcodes.tsv.gz、features.tsv.gz、matrix.mtx.gz。大部分分析单细胞的软件都可以读取这个文件做分析,如果有些软件不行的话,你也可以用单细胞的三大R包Seurat、Monocle、Scater来读取转化需要的格式,曲线救国也是可以的。

  假如现在你只有h5文件怎么办?你可能会说既然都能找到h5文件肯定也可以找到常用的表达量文件,当然了我也不会反对这种可能的。但是你有没有想过用h5文件来直接转化为表达矩阵呢!那么下面我就跟大家分享一下具体如何操作。
  首先先来介绍一下h5文件是什么,我估计有不少小伙伴都不怎么了解h5文件,下面来科普一下h5的基本格式介绍:H5文件是层次数据格式第5代的版本(Hierarchical Data Format,HDF5),h5格式主要有两个主要概念:dataset和group。 Dataset是类似于数组的数据集,而group是类似文件夹一样的容器,存放dataset和其他group。为了有直观地印象,可以把H5文件想想成一个文件系统,一个h5的最顶层是‘/’,然后是不同的组‘group’,每个组下面是数据‘dataset’,格式类似如下:

+-- /
|   +-- group1
|   |   +-- dataset1
|   |   |   +-- attribute1
|   |   |   +-- attribute2
|   |   |   +-- ...
|   |   |
|   |   +-- dataset2
|   |   |   +-- attribute1
|   |   |   +-- attribute2
|   |   |   +-- ...

  现在脑海中有了直观的印象,那么现在我们打开表达量的h5文件了,R包rhdf5、hdf5r都可以用来打开文件,这里我使用rhdf5包,示例代码如下:

 library(rhdf5)
> hd5 <- h5read('sample_bc_matrix.h5','/') #这里的‘/’可以替换为‘matrix’,这样数据的结构就会少一层
> str(hd5)
List of 1
 $ matrix:List of 6
  ..$ barcodes: chr [1:23130(1d)] "ccRCC_1_rep1@AAATGCCGTCTCAACA-1" "ccRCC_1_rep1@AACACGTAGATCACGG-1" "ccRCC_1_rep1@AACTTTCAGTCATCCA-1" "ccRCC_1_rep1@ACACCCTGTCGACTAT-1" ...
  ..$ data    : num [1:58298590(1d)] 1.54 1.54 1.54 1.54 2.13 ...
  ..$ features:List of 5
  .. ..$ _all_tag_keys: chr [1(1d)] "genome"
  .. ..$ feature_type : chr [1:18104(1d)] "Gene" "Gene" "Gene" "Gene" ...
  .. ..$ genome       : chr [1:18104(1d)] "GRCh38" "GRCh38" "GRCh38" "GRCh38" ...
  .. ..$ id           : chr [1:18104(1d)] "FO538757.1" "AP006222.1" "AL732372.2" "AL669831.5" ...
  .. ..$ name         : chr [1:18104(1d)] "FO538757.1" "AP006222.1" "AL732372.2" "AL669831.5" ...
  ..$ indices : int [1:58298590(1d)] 19 31 37 58 81 98 109 237 248 264 ...
  ..$ indptr  : int [1:23131(1d)] 0 968 2263 3364 3919 4920 6049 7129 8248 9509 ...
  ..$ shape   : int [1:2(1d)] 18104 23130

解释一下数据里面的变量:
  barcodes:细胞的barcode
  data:就是每个基因在每个细胞中的表达量
  features:记录了5个基因方面的属性
  indices:记录的是features中的基因位置
  indptr:可以计算出细胞中检测到哪些基因
  shape:概况描述,如这里是18104 基因,23130细胞
下面来展示一下具体怎么转化,示例代码如下:

>library(Matrix)

>barcodes <- hd5$matrix$barcodes
>counts <- hd5$matrix$data
>gene_id <- hd5$matrix$features$id
>indices <- hd5$matrix$indices
>indptr <- hd5$matrix$indptr
>shape <- hd5$matrix$shape

#用Matrix包的函数轻松转化为表达矩阵
>mat <- sparseMatrix(i = indices[], p = indptr[], x = as.numeric(x = counts[]), dims = shape[], dimnames = list(gene_id,barcodes))
#查看一下新建的表达矩阵的结构
>str(mat)
Formal class 'dgCMatrix' [package "Matrix"] with 6 slots
  ..@ i       : int [1:58298590] 19 31 37 58 81 98 109 237 248 264 ...
  ..@ p       : int [1:23131] 0 968 2263 3364 3919 4920 6049 7129 8248 9509 ...
  ..@ Dim     : int [1:2] 18104 23130
  ..@ Dimnames:List of 2
  .. ..$ : chr [1:18104(1d)] "FO538757.1" "AP006222.1" "AL732372.2" "AL669831.5" ...
  .. ..$ : chr [1:23130(1d)] "ccRCC_1_rep1@AAATGCCGTCTCAACA-1" "ccRCC_1_rep1@AACACGTAGATCACGG-1" "ccRCC_1_rep1@AACTTTCAGTCATCCA-1" "ccRCC_1_rep1@ACACCCTGTCGACTAT-1" ...
  ..@ x       : num [1:58298590] 1.54 1.54 1.54 1.54 2.13 ...
  ..@ factors : list()

>mat[19:26,58:59]
8 x 2 sparse Matrix of class "dgCMatrix"
           ccRCC_1_rep2@CAGATCAAGCAATATG-1 ccRCC_1_rep2@CAGCGACCACAGACTT-1
TNFRSF4                          1.2251890                         .
SDF4                             0.9567439                         .
B3GALT6                          .                                 .
C1QTNF12                         .                                 .
AL162741.1                       .                                 .
UBE2J2                           0.5886769                         .
SCNN1D                           .                                 .
ACAP3                            .                                 1.58509

  现在是不是觉得很简单,有点意犹未竟的感觉。以后在遇到只有h5表达量文件的时候,你就可以信手拈来不必惊慌了。

最后

  emm,今天就分享到这里,希望可以帮到还不会的朋友们,你是不是也学会了,赶快操作起来吧!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容