grep-sed-awk

grep
文本搜索工具,类似于正则表达式搜索,可以在一个大的文件中快速搜索到满足一定规则的内容。

#案例一:统计fasta文件中序列的条数;
grep -c “>” gene.ffn
#案例二:输出满足条件的序列;
grep -A 2 “3 gi 29732 34486” lastz.axt
#案例三:筛选出不满足条件的内容;
ps -fx | grep -v “S”

sed
sed = Stream Editor
流处理器,sed有非常强大的功能.

#案例一:输出固定的行
sed -n ‘1307p’ seq.fna #输出文件第1307行;
sed -n ‘100,200’ seq.fna #输出文件第100到200行;

#案例二:替换操作
sed -e ‘s/gi/GI/’ seq.fna #将文件中gi全部替换为大写GI;
sed -i ‘s/gi/GI/g’ seq.fna #在原文件上进行替换,并且进行全部替换;
sed -i.bak ‘s#GI#gi#’ seq.fna #在原文件上进行替换,并进行备份;
sed -e ‘s/gi/GI/2;s/ref/REF/2’ seq.fna #只将第二次出现的gi和ref进行替换;
sed -f sed.list cds.list #根据文件中的模式进行替换,可同时进行多条件替换;
sed -n ‘s/gi/GI/p’ seq.fna #打印发生替换的行;

#案例三:删除空白行;
sed -e ‘/^\s*$/d’ seq.fna #删除文件中的空白行;

#案例四:行寻址
sed -n ‘/ref/p’ seq.fna #输出文件中包含ref关键字的行;
sed ‘100,2000s/GI/gi/g’ seq.fa #则只替换100行到2000行的内容;
sed ‘100,2000!s/GI/gi/g’ seq.fa #加感叹号取反,在这个范围之外的执行操作;

#案例五:删除操作
sed -e ‘/>/d’ seq.fna #删除包含ref的行;
sed -e ‘s/:.*//g’ seq.fna #删除冒号之后的所有内容;

#案例六:对应替换,类似于tr的功能
sed -e ‘y/ATCG/atcg/’ seq.fna #修改大小写
sed -e ‘/>/!y/ATCG/atcg/’ seq.fna #DNA序列反向互补配对,并修改大小写

awk
awk也是非常强大的文本处理工具,awk本身也是一门编程语言;

#案例1:输出一个列表任意行;
awk ‘{print $1}’ blast_m8.out #输出blast m8 格式结果的第一行;
awk -F “:” ‘{print 1 , 1, 1,NF}’ passwd.list #通过-F修改默认分隔符为冒号,输出第一行与最后一行;

#案例2:格式转换
awk ‘{print"@" $1"\n"$10"\n""+\n"$11""}’ all.sam #将短序列比对上的reads输出出来,生成fastq文件;

#案例3:过滤blast结果
awk ’{if ($3>=80 && $4>=100) print $0}’ blast_m8.out #过滤blast比对结果,将identity 大于80,并且比对长度大于100bp的结果输出;

#案例4:比较
awk ‘$8>$10’ input.txt #输出第8列大于第10列的行。

#案例5:匹配输出
awk ‘$0~ /wang/{print $0}’ passwd.list #利用正则表达式,将秘密表中姓wang的账户都输出出来;

#案例6:格式化输出
awk ‘BEGIN{print “The Program Begin\n”}{if ($3>=80 && $4>=100) print $0}END{print " The Program End\n"}’ input.txt #利用BEGIN和END关键字生成报告;

#案例7:修改字段和记录分隔符
awk ‘BEGIN{OFS="\t"}{print $2,$4,$5}’ input.txt #在BEGIN中设定字段分隔符和记录分隔符;

#案例8:awk编程计算
awk ‘{x+=$3}END{print x/NR}’ input.txt #计算第三列的平均值,最后在END将其输出出来。

#案例9:awk编程比较大小
awk ‘BEGIN { max=100 ;print “max=” max} {max=($1 >max ?$1:max); print $1,"Now max is "max}’ input.txt #取得文件最后一个域的最大值。

#案例10:awk编程求和
awk ‘{print $0,$3+$4}’ input.txt #计算第3列和第4列的和。

#案例11:输出固定行内容
awk ‘NR>=20&&NR<=80’ input.txt #输出第20到第80行内容。

#案例12:合并文件
awk ‘BEGIN{while((getline<“file1”)>0)l[$1]=$0}$1 in l{print $0"\t"l[$1]}’ file2 #将两个文件按列合并起来,类似jion命令的功能。

#案例13:去重复
awk ‘!($0 in a) {a[$0];print}’ input.txt # 打印不重复的行,类似uniq的功能;
awk ‘!($2 in l){print;l[$2]=1}’ input.txt #计算第二列内容非冗余的次数,类似于uniq的功能;

#案例14:统计字符
awk ‘{for(i=1;i!=NF;++i)c[$i]++}END{for (x in c) print x,c[x]}’ input.txt 计算每个字符出现的次数,类似wc的功能。

#案例15:替换
awk ‘{sub(/test/, “no”, $0);print}’ input.txt 进行替换,类似sed的功能,

#案例16:fastq转换为fasta
awk ‘{getline seq;getline plus;getline qual;sub("@",">",$0);print $0 "\n"seq}’ test.fastq;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值