linux质控命令,Biostar_handbook||Charpter_6789_数据的格式_获取_质控_seqkit

本文主要是介绍linux质控命令,Biostar_handbook||Charpter_6789_数据的格式_获取_质控_seqkit,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Charpter6:数据的格式Data Formats

常用数据库

NCBI

EBI

Uniprot

Phytozome

Ensemble plants

TAIR

PlantGDB

PlantTFDB 植物转录因子数据库

这些是我目前常用的一些数据库,可以看出来我是做植物的。其实植物领域还有许多重要的数据库,更不必说动物的了,各个物种都能拿出来做个数据库。数据这么多,如何更加高效的从数据库中实现你想要的目的是门学问。而自己目前对这些数据库知道的也只是初步的一些东西。其实除了NCBI外很多重要的数据库都有一些很实用的功能,但是却缺少教程指导推广,以后有机会可以再对一些数据库的功能进行探索探索。

数据格式

1. GeneBank format

最常见的生物数据存储方式FASTA,GeneBank, FASTQ,前两者被称为curated sequence information.

Genebank/gb格式文件为NCBI存储基因信息的格式。其中NCBI里的RefSeq数据库为标准非冗余的基因数据库.(It provides the Sequences Record and Baseline for biological studies and it's a non-redundant set of reference standards derived)

0abce878c1a1?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

用readseq对gb数据转换:

efetch -db=nuccore -format=gb -id=AF086833 > AF086833.gb

###转gb到cds序列fasta序列

readseq -p -format=FASTA AF086833.gb ## complete genome seq

readseq -p -format=FASTA -feat=CDS AF086833.gb

readseq -p -format=GFF AF086833.gb

readseq -p -format=GFF -field=CDS AF086833.gb

2. FASTA

就是第一行以'>'开始的序列的各种信息,第二行具体atgc

3. FASTQ

二代测序数据存储格式,第一行'@',第二行''序列,第三行'+或者序列信息'',第四行测序的数据质量。

Charpter 7: 获取序列How to get DATA

1. 通过LINUX系统直接从NCBI上下载数据

### 以genebank格式序列下载

efetch -db=nuccore -format=gb -id=AF086833 > AF086833.gb

### 以fatst格式下载序列

efetch -db=nuccore -format=fasta -id=AF086833 > AF086833.fasta

### 取序列的某一段

efetch -db=nuccore -format=fasta -id=AF086833 -seq_start=1 -seq_stop=100

## 互补序列

-strand 1

-strand 2

通过对文章里的project accession 号来下载数据,以PRJNA257197为例子**

esearch -db nucleotide -query PRJNA257197

esearch -db nucleotide -query PRJNA257197 | efetch -format=fasta > genomes.fa

-db=protein

2. 下载SRA数据库数据

SRA数据库(short read Archive):数据存储的格式

Bioproject:PRJN开头,研究项目的介绍

BioSample:SRS/SRMN开头,生物样品来源的介绍

SRA Experiment: 单独样本的测序文库

SRR Run:直接相关数据存储格式

==根据eseach 和 efetch直接下载数据== (都不用各种网站点了,实用下载数据新技能!!!)

esearch -db sra -query SRP020911 | efetch -format runinfo >SRP020911.csv

## 查看csv第一行标题信息

head -1 SRP020911.csv |tr ',' '\n'|nl ### 第一列为 SRR信息号,第十列为SRR的下载地址

### 获取SRR的信息号,SRR下载地址

cat SRP020911.csv| tail -n +2 | cut -d, -f 1

tail -n +2 | cut -d, -f 10

### 结合xargs直接完成数据的下载:

cat SRP020911.csv| tail -n +2 | cut -d, -f 1 | xargs -i prefetch {}

cat SRP020911.csv| tail -n +2 | cut -d, -f 10 | xargs -i echo wget {} \&

3. 对Seqkit工具的应用

对fq文件基本情况统计seqkit stat *.gz

统计每个序列的GC情况 seqkit fx2tab --name --only-id --gc *.gz

==根据id号提取序列==

### 随机创造个id列表

seqkit sample -p 0.001 duplicated-reads.fq.gz |seqkit seq --name --only-id > id.txt

###根据id列表提取序列

seqkit grep --pattern-file id.txt duplicated-reads.fq.gz

或者-f参数

### 提取目标序列

seqkit grep -p "AT1G30490.1" ath.pep.fa

去除掉含有简并碱基的序列如N/K等

### 生成含有简并碱基序列的id

seqkit fx2tab -n -i -a viral.1.1.genomic.fna.gz | csvtk -H -t grep -f 4 -r -i -p "[^ACGT]" | csvtk -H -t cut -f 1 > id.txt

### 去除id.txt,即反向匹配。

seqkit grep --pattern-file id.txt --invert-match viral.1.1.genomic.fna.gz > clean.fa

### 定位这些含有简并碱基的序列。

seqkit grep -f id2.txt viral.1.1.genomic.fna.gz |seqkit locate -i -P --pattern K+ --pattern N+

定位motif

## 以文件中的motif为标准定位

seqkit locate --degenerate --ignore-case --pattern-file enzymes.fa viral.1.1.genomic.fna.gz

### 根据自己的指定的motif序列定位,可包含简并碱基

seqkit locate -i -d -p CHWWWWWWDG seq.fa

根据序列的长短从小到大排序

seqkit sort --by-length virus.fna.gz > virus.genomics.sorted.fa

文件过大用 --two-pass

Charpter 8:二代三代测序数据基本信息Sequencing instruments

DNA sequencing at 40: past, present and future

0abce878c1a1?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

1. 测序仪器

一代测序:Sanger法,利用加不同荧光的双脱氧核苷酸ddNTP会中止PCR。

速度快,一次只能一条,1000bp~1500bp左右

二代测序:以Illumina为代表边合成边测序。对随机打断成150~300bp的短片段 +上固定碱基的接头(adapter)+标签(tag/index)。

由于建库中利用了PCR富集序列,因此有一些量少的序列无法被大量扩增,造成一些信息的丢失,且PCR中有概率会引入错配的碱基

三代测序:

单分子荧光测序(SMRT):

纳米孔测序

无需扩增,基于纳米科技,对单分子链DNA/RNA直接用合成/降解/通过纳米孔等方式直接测序

2. 错误率

ILLUMINA 0.1%的错误率,理论上一条序列的测序准确度是递减的,也就是前面准确度高,后面低。且在一些GC率高的区域,测序质量会显著降低。

PacBio 10%的错误率

MinION :最高达到20%的错误率,且错误多为固定错误,无法通过测序深度来矫正。

可以看到三代测序的数据错误率都很高,所以常需要加测二代的数据来对三代数据矫正。

Charpter 9:测序质控

分为两步:第一步FastQC/MultiQC展示测序的质量;第二步Trimmomatic/fastp去除低质量序列

1. FastQC/MultiQC 显示测序质量

### 下载数据

wget http://data.biostarhandbook.com/data/sequencing-platform-data.tar.gz

tar xzvf sequencing-platform-data.tar.gz

### 直接fastqc显示测序质量

ls *.fq.gz |parallel fastqc -o ./ --nogroup {} &

### MultiQC批量显示测序的质量

##在已经用fastqc得到测序的html文件和zip文件夹

multiqc *fastqc.zip --pdf

在运行过程中曾出现too many levels 错误,需要调用fastqc软件的绝对地址来运行程序

2. Trimmomatic/fastp质量控制

用Trimmomatic 从5‘端开始切除低质量碱基(LEADING:5)TRAILING:20表示切除碱基质量小于20的碱基,MINLEN:50表示过滤切除后长度小于50个碱基的reads

滑动窗口:SLIDINGWINDOW:3:20表示设置窗口大小为3个碱基,从5'端开始切除reads,read的平均质量低于20,开始切除后边的碱基序列。过滤长度小于50碱基的reads,使用更大的窗口可以减轻切除的力度

trimmomatic PE SRR11111_1.fq SRR11111_2.fq trimmed_1.fq unpaired_1.fq trimmed_2.fq unpaired_2.fq ILLUMINACLIP:/home/wangtianpeng/anaconda3/share/trimmomatic-0.36-5/adapters/TruSeq3-PE-2.fa:2:30:10 LEADING:5 TRAILING:5 SLIDINGWINDOW:4:5 MINLEN:20

trimmomatic PE SRR1553607_1.fastq SRR1553607_2.fastq trimmed_1.fq unpaired_1.fq trimmed_2.fq unpaired_2.fq SLIDINGWINDOW:4:30

去除特定的adapter

cat ~/miniconda3/envs/bioinfo/opt/fastqc-0.11.5/Configuration/adapter_list.txt

echo ">nextera" > nextera.fa

echo "CTGTCTCTTATACACATCTCCGAGCCCACGAGAC" >> nextera.fa

## 最后加上ILLUMINACLIP:参数

ILLUMINACLIP:adapter.fa:2:30:5

一键化软件fastp

###一键化输出

fastp -i in.R1.fq -o out.R1.fq -I in.R2.fq -O out.R2.fq

### 默认自动化去接头,如果不需要参数-A

### PE 数据的碱基校正 PE 数据的每一对 read 进行分析,查找它们的 overlap 区间,然后对于 overlap 区间中不一致的碱基,如果发现其中一个质量非常高,而另一个非常低,则可以将非常低质量的碱基改为相应的非常高质量值的碱基值

-c 参数使用

fastp -q 30 -5 -l 100 -i il_1.fq.gz -I il_2.fq.gz -o i1_clean_1.fq -O i1_clean_2.fq

这里标准为:平均质量高于Q30,对5‘端进行低质量碱基删除,保留大于100bp的短读。

fastp -3 -W 4 -M 20 -a AGATCGGAAGAG -i $i.fastq.gz -o ../clean_data/fastp_out_2.0/$i.qc.fq.gz

对3'端低质量碱基删除,-W -M 为sliding window参数 -a 指定接头序列

这篇关于linux质控命令,Biostar_handbook||Charpter_6789_数据的格式_获取_质控_seqkit的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_42298412/article/details/116576627
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/219259

相关文章

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Kali Linux安装实现教程(亲测有效)

《KaliLinux安装实现教程(亲测有效)》:本文主要介绍KaliLinux安装实现教程(亲测有效),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载二、安装总结一、下载1、点http://www.chinasem.cn击链接 Get Kali | Kal

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU