查看原文
其他

碱基们的时间 2018-06-01

本文介绍了一个用于常见生物信息文件格式如 .fastq, .fasta, .sam 可读性增强的工具。

首先放出效果图预览:

以及:

  • github repo: https://github.com/Nanguage/bioView

  • 下载地址: https://github.com/Nanguage/bioView/releases

设计初衷

在很多时候,生物信息分析几乎是一直在围绕着某一些特定格式的文件格式进行的,比如 fasta, fastq, sam, bam 等等。也许是考虑能使得文件容易被程序解析,或是容易被人所阅读,这些文件格式中的很大一部分都被设计成了文本文件。另外考虑到这些文件的大小,动辄就是十几甚至几十上百 G ,所以我们一般不会使用常规的文本编辑器打开,而是使用 Unix 下的 less, head, tail 等工具来对其进行查看。而这些工具默认情况下并不支持对这些生物信息特定文件格式的色彩高亮、重排版等功能,造成了我们在对文件进行观察、检查时存在较大的认知障碍,难以快速从中观察出符号串之中潜在的模式、规律。

至少对于我来说,在很多情况下这对我的工作造成了麻烦,比如在有些时候,我想在写代码前确定某一段实验中设计的 index 序列在 fastq records 中的大概位置,以便我对程序进行调整。但使用 less 进行查看时,面对整屏幕的黑白字符,难以从其中一眼看出 index 序列所处的位置。又比如说,有时在对 fastq 文件进行预处理时,需要将 reads 末端低质量的序列 trim 掉,但有时候软件默认的参数并不能满足需求,需要进行参数调整,需要对处理前后的 fastq 进行比较,以确定合适的参数。通常会用 fastqc 来生成质量报告来进行检查。这时候如果能够直观地观察 reads 中碱基的质量情况就会很有帮助,而 less 看到的是黑白的 phred 质量字符,很难肉眼分辨质量的高低。

为了解决上述不便,我寻找了一些办法,比如 bioSyntax,它提供了 less, vim, sublime, gedit 中的生物信息专属的语法高亮解决方案,并且支持 .sam, .flagstat, .vcf, .fasta, .fastq 等多种文件格式。

当然,bioSyntax 是一个非常棒的东西。但它也有些地方让我觉得不够方便。首先就最常用的 less 而言(其他的编辑器对大文件支持差,所以我这样认为..),安装上稍微有些不便,需要使用 root 权限通过 apt 来进行安装,而很多时候做生信工作都是在公家的服务器上完成的,并没有 root 权限,(虽然可能也有别的解决办法,但也许还要折腾..)这一点就不是很友好。其次它的配色让我感到不是很令人愉悦,并且它也没有提供出其它简单易行的配色配置方案。还有很重要的一点,bioSyntax 仅仅提供了生信文件的语法高亮,我认为对于可读性的加强来说这是不够的,这只是其中一个方面,为了更清晰地展示,最好还能对文件进行重排版。比如对于 sam 文件,标准的文件格式中每一行有 11 列,信息密度非常高,当然这样设计机器 parse 起来比较方便,但人阅读起来就不舒服了。为了能加强它的可读性,最好能对它进行简单的二次排版。

总结起来,一个我所需要的,理想中的 bioinfo 文件格式可读性增强软件应该具有以下特性:

  1. 提供彩色的语法高亮

  2. 支持简单的重排版

  3. 高度可配置,可以切换配色、排版格式等

  4. 易于安装

  5. 运行效率高,使用中无卡顿

  6. 支持 Unix 中的管道操作,与 less, head, tail 无缝衔接。

以上也就是我设计,编写 bioView 的初衷。

bioView

安装

提供了编译好的可执行二进制文件供下载,无需安装其他依赖,下载压缩包后解压即可使用。下载地址: releases

:如果系统是旧的 glibc 版本,或者是默认的版本使用时出现提示,可下载 bioview-0.1.1-old_glibc.zip

考虑到生信分析大多在 Linux 平台进行,目前只提供了 Linux 平台的版本,当然因为是用 Nim 语言编写的,所以是本身是可以跨平台的,如果需要其它操作系统的版本,可以下载源码进行编译,参考这里

shell 辅助函数

另外可以选择添加辅助的 shell 函数,以便使用。虽然只是对原有命令的简单包装,不影响核心功能,但多少能节省点打字时间。只需要将下列文件加到 配置文件(比如对于 bash shell 的 ~/.bashrc) 的最后并修改第一行的文件路径到 bioview 所在的路径即可。现支持 bash 与 fish:

  • bash

  • fish

基本使用

目前尽支持最常用的三种文件格式 .fasta .fasta 和 .sam(.bam),对其它格式的支持还有待开发。
首先通过 -h 来显示使用说明:

$ bioview -h
Command line tool for bioinformatics file format readability enhancement.
Usage:
 bioview fq <file> [--config-file=<config_file>] [--hist=<yes/no>] [--color=<yes/no>] [--phred=<33/64>] [--delimiter=<yes/no>]
 bioview fa <file> [--config-file=<config_file>] [--color=<yes/no>] [--type=<dna/rna/protein>]
 bioview sam <file> [--config-file=<config_file>] [--hist=<yes/no>] [--color=<yes/no>] [--phred=<33/64>] [--multiline=<yes/no>]
 bioview color-atla
 bioview example-config
 bioview (-h | --help)
Options:
 -h --help        Show this help information.
 --phred=<33/64>  Quality score encode for fastq file, 33 or 64. [33]
 --hist=<yes/no>  Show quality hist or not. [yes]
 --delimiter=<yes/no> Show fastq record delimiter or not. [yes]
 --multiline=<yes/no> Show multiple line format of sam file. [no]
 --color=<yes/no> Show color height light of bases or not. [yes]
 --type=<dna/rna/protein>       The record type of fasta file. [dna]
 --config-file=<config_file>    The path to config file. [~/.config/bioview/config.json]

你可以把 bioview 想象成一个着色器,输入的是原始的文本文件,输出的是经过渲染的结果。现在我们用它来渲染一个 fastq 文件。并将结果传流到 less 中进行查看:

$ bioview fq example.fq | less -rS

这里 less 需要加 -r 参数用于色彩显示。你会在终端看到:

与普通的用 less 对文件进行查看并无太大区别,只是将碱基带上了颜色,并且在 reads 的第4行,将难以理解的质量字符替换成了柱形图,高低代表质量的好坏,越高即质量越好。同时在不同的 records 之间添加了分割线,以便更加清晰地区分。

同时这些视觉元素,比如颜色、柱形图、分隔符,可以通过参数来选择是否对其进行显示,比如:

$ bioview fq example.fq --color=no | less -rS # 不显示颜色
$ bioview fq example.fq --hist=no | less -rS # 不显示柱形图
$ bioview fq example.fq --delimiter=no # 不显示分隔符

支持通过管道进行输入,比如先对文件进行解压缩然后通过管道输入 bioview, 只需要将文件名替换为 - 即可:

$ zcat example.fq.gz | bioview fq - | less -rS`

恩,命令貌似有点长,为了节约打字时间,可以通过 shell 辅助函数简化:

shell 辅助函数包括:

  • bio-less : 对 bioview + less 的包装

  • fq-less : 对 bioview fq + less 的包装

  • fa-less : 对 bioview fa + less 的包装

  • sam-less : 对 bioview sam + less 的包装

比如:

$ bio-less example.fq # 等价于 bioview fq example.fq | less -rS
$ fq-less example.fq # 与上述命令等价
$ zcat example.fq.gz | fq-less - # 等价于 zcat example.fq.gz | bioview fq - | less -rS

对 fasta 和 sam 的操作也是类似的,这里不再赘述。
值得一提的是 sam 可以通过 --multiline=yes 来排版为多行模式,降低信息密度,方便阅读:

$ bioview sam example.sam --multiline=yes | less -rS

配置文件

上面说了,我想要的是一个可以灵活地对配色、排版等进行配置的软件。所以 bioView 加入了配置文件功能,能够对色彩和视觉元素进行相对于命令行参数更细节配置。

默认的配置文件存放目录位于 ~/.config/bioview/config.json,也可以通过 --config-file 指定配置文件。

主题

每种配置可以视为一种风格主题(theme)。

默认的是 simple theme,我还提供了另外两种 theme:

  • verbose:冗余风格,相较于 simple 提供更加复杂多彩的样式

  • emoji: 通过 emoji 来代替柱状图显示测序质量。(也许没什么用,纯属好玩 :P ,btw. 这个创意来自于这里)

我提供了一种一键式的主题切换方案,可以通过一行简单的命令在不同的 theme 之间切换。
比如切换到 verbose:

$ mkdir -p ~/.config/bioview/ ; curl -LJ https://raw.githubusercontent.com/Nanguage/bioView/master/theme/verbose.json n -o ~/.config/bioview/config.json

其它的主题以及切换代码请参考这里。

制作自己的私人配置文件

由于本人没什么艺术细胞,所以仅仅制作了两种 theme,当然你可以制作你自己的 theme。
可以通过,bioview example-config 来生成一个配置文件的模板。然后对其进行编辑

$ mkdir -p ~/.config/bioview/config.json
$ bioview example-config > ~/.config/bioview/config.json
$ vim ~/.config/bioview/config.json

配置文件为 json 格式,全局的配置储存在最外层的字段中,比如 base_color, 代表不同碱基的颜色,内层的 base_color::fg 为前景色(foreground),而 base_color::bg 为背景色(background),其数值为终端内支持的颜色的编码。可以通过 bioview color-atla 输出色卡进行颜色的编码确认。

$ bioview color-atla

而对于 fq, fa, sam 特定格式相关的配置位于相应的字段 fq-config, fa-config, sam-config。可以根据需要对其进行相应的配置。

开发

目前为止,bioView 虽然已经基本达到上面我所说的几个目标,但是仍然是一个不完整的,有待开发的项目。后续还需要提供对其它生信文件格式的支持,以及对现有功能进行测试与调整。欢迎大家提出意见与建议,可以在 github 上直接提 issue,或者邮件联系我。
邮箱:nanguage@yahoo.com 。
同时如果你喜欢本项目的话,欢迎来点个 star, 也欢迎 fork, pull request 大家一起进行开发。

看完你还想看


欢迎大家来投稿!

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存