Linux

Pipeline

Data Structure

GFF全称为general feature format,这种格式主要是用来注释基因组。

GTF全称为gene transfer format,主要是用来对基因进行注释。

目前两种文件可以方便的相互转化,比如:使用Cufflinks软件的 的gffread。GTF文件由9列数据组成,这两种文件的前8列都是相同的(一些小的差别),gtf文件是以tab键分割的9列组成,以下为每一列的对应信息:

GTF/GFF文件注释信息

1.2.1 先创建一个自己的文件夹

1.2.2 下载

1) 下载方法1: 可以从terminal下载:

2) 下载方法2: yeast基因组注释文件可以从浏览器下载:

Download Link 1

Download Link 2

1.2.3 解压缩

首先将*.gtf.gz放到自己创建的目录下(可以使用cp或者mv命令), 然后解压缩该文件:

Inputs&#Outputs-Notes

本节内容主要Inputs是以下的Linux命令工具,本教程提供的example文件是1.gtf,按照前文指导,在docker 目录/home/cs/Bioinfo_Lab/0.Linux创建自己的文件夹,并下载example文件1.gtf。(通过example练习,理解并掌握以下这些命令,特别是awkcatcutgrepwc的用法其参数的用法是本章学习的重点和难点,也是主要的homework之一。)

Running Scripts

本章内容主要是学会用Linux的一些简单编程方法去查看GTF/GFF基因组注释文件的基本信息,并学会对文件中数据进行提取,利用提取到的数据计算特定feature(例如计算基因积累长度等)。顺利掌握以下操作的前提是,必须熟悉GTF/GFF文件的注释信息,特别是要每一列对应的内容是什么。进行以下操作前,先启动Docker,进入上一章创建的bioinfo容器,并且下载并解压缩本教程配套1.gtf文件(本教程提供的是yeast基因组注释文件)。当做好这些准备工作,开始以下操作(Tips/Utilitie部分对Linux命令行格式及一些参数符号进行简单注释,可供参考)。

注意:如果挂载主机目录,请注意切换工作目录。

step1.查看文件基本信息

尝试输入以下命令,分别查看1.gtf文件的开头、结尾、文件的大小、行数等基本信息。

step2.数据提取

首次尝试,先复制以下命令,分别提取1.gtf文件的特定列、行等数据信息;观察输出结果,然后建议尝试修改以下命令中的参数,进行更多的练习。

2.1 筛选特定的列

2.2 筛选特定的行

Step3.提取和计算特定的feature

这一阶段是在学会step2的基础上,进一步的学习。首次尝试,先复制以下命令,观察输出结果,然后建议尝试修改以下命令中的参数,进行更多的练习。

3.1 提取并统计featrue类型

3.2 计算特定feature特征长度

3.3 分离并提取基因名字

step4.提取数据并存入新文件

这一阶段主要是学会提取数据并存入新文件,例如,寻找长度最长的3个exon, 汇报其长度

这里介绍两种方法。

第一种是直接提取并计算最长3个exon, 汇报其长度,存入txt文件;

第二种方法是写一个可执行文件run.sh,寻找长度最长的3个exon,汇报其长度。

4.1 提取数据存入txt文件示范

输入命令如下,则可将结果存入新文件1.txt,这里提取并存入的命令是>

然后输入命令less -S 1.txt 或者vi 1.txt 则可进入vi一般模式界面显示输出结果,例如:

vi简单使用教程详见Tips,此时,在英文输入法状态下按:q:wq可以退回到终端sell窗口。

如果docker挂载了主机目录,则可访问主机目录查看1.txt文件。

4.2 可执行文件编辑示范

第一步,输入命令vi run.sh,进入vi编辑界面。

第二步,按i键切换至insert模式后,写下rush.sh的文件内容如下:

(第一行语句一般用来声明这个脚本使用的shell名称,“#”后的语句可作为批注,在执行时会被忽略)

第三步,按escctrl+[切回普通模式,输入:wq退出vi编辑器,在命令行后键入:

输出如下所示,与1.txt的内容一致。

Tips/Utilitie

1. Linux命令行格式通常写法如下:

命令 (空格)选项(空格)参数1 参数2... mv -f folder1 folder2

注意:命令、选项、参数之间一定要用空格来区分!

2. 两种表达方式:短格式 vs 长格式。

① 短格式的命令选项:用一个“-”和一个单个英文字母表示,如“-a”。

② 长格式的命令选项:用两个“-”和一个英文单词表示,如“--help”。

即 ls -h 与 ls --help 或者 ls -a 与 ls --all 所起的作用都是相同的。

3.cd——进入工作目录

一般的程序后面都要输入文件位置和名称,告知程序输入和输出是什么:

./filename 指当前目录下的文件 ../filename 指上一级目录下的文件 ../../filename 指上两级目录下的文件.

4."|"是管道命令操作符,它可以将左边命令传出的正确输出信息(standard output)作为右边命令的标准输入(standard input)。

5.建议在对*.gtf文件执行的一些命令行Inputs末尾加上| head -n 或者 | tail -n,然后Outputs会自动显示文件前n行或者后n行;否则,屏幕会被刷屏。

6.星字符:* 可以代表任何字符,称之为wildcard。

7.vi文本编辑器使用,主要就是模式之间的切换,如下图所示。

Homework and more

homework

  1. 阅读《鸟哥的Linux私房菜-基础学习篇》(第5-10章推荐章节)

  2. 查找、理解并注释上述每一个语句和参数的意义

  3. 解释gtf/gff文件中第4、5列($4,$5)代表什么,exon长度应该是$5-$4+1还是$5-$4?

  4. 有新的方法加分,但必须注释清楚每个语句和参数的意义和结果。??

more

本章主要参考以下几篇生信数据文章:

https://www.jianshu.com/p/48b5a0972301

https://blog.csdn.net/sinat_38163598/article/details/72851239

https://zhuanlan.zhihu.com/p/36065699

https://gist.github.com/sp00nman/10372555

https://www.jianshu.com/p/7af624409dcd

Last updated