2、awk的输出
1、常见的输出格式整理
awk '{print "this is " $1, $2, $1*$2, NR, NF, $NF}' file1 ###字符输出,字段输出,运算输出,内置变量输出等,默认空格分开;$1 ,$2调换顺序打印随之变化
awk 'BEGIN{FS=OFS="\t"} {print $1,$2 }' file2 ###读入字段分割,输出字段分割
awk -F '[ :\t|]' '{print $1}' file ##可以有多个分割符
awk {printf ("this is\t%d\t%.2f %s %s %s\n",NR,NF,$1,$2,$NF)}' file3 ###printf( )不自动换行;%d ,%.2f, %s;字段分割也可以指定
awk '{$2="";print }' file ##不打印第二列
2、选择
数字选择:awk '$2 > 10{print}' file ###+ - * / % ^ ; >= <= != == ; ~ !~ /gene/ || /mNA/
字符选择 :awk ‘$2 == "gene" {print}’ file
awk '/mRNA/{match($9,/ID=(.*);P/,a);printf "%s\t%s\t%d\t%d\n",$1,a[1],$4,$5}' Chr_genome_final_gene.gff3 ##生成circos的gff文件
awk '{gsub(/gene/,"gene_id",$3);print}' Chr_genome_final_gene.gff3|less ##替换处理
正则匹配:awk ‘ /gene/ {print}’ file ###^ $ . [] \ | () * + ?
组合选择:&& || ! 和and or not
awk ‘$2 >=10 && $3<=20 {print}’ file
文本处理开始于结束BEGIN{} END{}
3、计算
数字计算:awk '{a+=2}END{print a}' file
字符串联:awk '{a = a " " $1} END{print a}' file 或者 awk '{a = a $1 " "} END{print a}' file
总行以及最后一行:awk '{last = $0}END{print NR, last}' file
内建函数:length($0) ##$0不包含换行符
每一行所有字段和:awk '{ sum = 0; for( i = 4; i <= 5; i++){printf("%d\t" , $i); sum += $i };print sum }' ##打印4,5列,计算每行的4到5列的和
所有行字段和:awk '{ for( i = 4; i <= 5; i++){ sum+=$i }}END{ print sum }'
4、流程控制语句
if() print else print
while(){}
for (i=0; i<=5;i++){}
for (i in a) {}
next ; break
4、数组
awk '{a[NR] = $0} END{ for(i = 1;i <= NR;i++)print a[i]}' file
5、常用内建字符串函数
index(r , t) match(s , r ,arr) sprintf split(s ,arr, fs) gsub(r ,s, tar) substr(s, star, len)
2、awk的输出的更多相关文章
- shell编程系列15--文本处理三剑客之awk格式化输出printf
shell编程系列15--文本处理三剑客之awk格式化输出printf printf的格式说明符 格式符 含义 %s 打印字符串 %d 打印十进制数 %f 打印一个浮点数 %x 打印十六进制数 %o ...
- awk内置字符串函数 awk 格式化输出
i249 ~ # ps -efl|head -1|awk '$2~/S/{print $2}'Si249 ~ # ps -efl|awk '$2~/S/{print $2}'SSSS printf - ...
- 使用awk格式化输出文本
注意:本文并不是一篇awk入门文章,而是偏重实例讲解 awk借鉴了c语法,因此awk在许多地方还保留有c语言的痕迹,比如printf语句:for,if的语法结构等 介绍 最简单地说,AWK 是一种用于 ...
- linux:awk修改输出分隔符
file1的内容如下: a b c d e f g h 现在想要修改成 a b c:d e f g:h 则需要用到如下命令: awk -F " " '{print $1,$2,$3 ...
- awk应用
h3 { color: rgb(255, 255, 255); background-color: rgb(30,144,255); padding: 3px; margin: 10px 0px } ...
- awk(1)-简述
1.概述 AWK is a programming language designed for text processing and typically used as a data extract ...
- awk语法
awk是一个非常棒的数字处理工具.相比于sed常常作用于一整行的处理,awk则比较倾向于将一行分为数个“字段”来处理.运行效率高,而且代码简单,对格式化的文本处理能力超强.先来一个例子: 文件a,统计 ...
- awk命令--update20150120
简介 awk是一个强大的文本分析工具,把文件逐行读入,以空格为默认分隔符分割成field,切开的部分再进行各种分析处理. 模式和动作: 任何awk语句都是由模式和动作组成,模式部分决定动作语句何时触发 ...
- awk 手册--【转载】
1. 前言 有关本手册 : 这是一本awk学习指引, 其重点着重于 : l awk 适于解决哪些问题 ? l awk 常见的解题模式为何 ? 为使读者快速掌握awk解 ...
随机推荐
- Write operations are not allowed in read-only mode 只读模式下(FlushMode.NEVER/MANUAL)写操作不
org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read ...
- jquery移除、绑定、触发元素事件
unbind(type [,data]) //data是要移除的函数 $('#btn').unbind("click"); //移除click $('#btn').unbind() ...
- 编程实现从hadoop上下载
下载 package hadoopTest; import java.io.File; import java.io.IOException; import org.apache.hadoop.con ...
- Hibernate 查询语句用法记录
Hibernate 查询MatchMode的四种模式 MatchMode.START:字符串在最前面的位置.相当于"like 'key%'" MatchMode.END:字符串在最 ...
- centos7 & ubuntu14.02安装sublime 3
Centos7安装Sublime Text 3.0正式版 1.安装 GPG 公钥rpm -v --import https://download.sublimetext.com/sublimehq-r ...
- 插耳机对orientation sensor的影响
偶然发现,耳机孔插上耳机对手机的磁感应器有非常大的影响. 具体影响的方式和解决的方法,慢慢研究下
- xshell 使用密钥登录
http://blog.csdn.net/suquan629/article/details/44783377
- Manager Test and DAO
1. 阅读ManagerTest代码 (1)代码 import java.util.* package test; /** * This program demonstrates inheritanc ...
- apache 2 修改虚拟目录
准备好环境,就要开始进行开发了.这一篇,我们在Ubuntu Apache上配置虚拟目录. 知识准备: 区别于Windows 下apache,配置文件通常只有一个,就是httpd.conf. Linux ...
- Java-Runoob:Java 循环结构
ylbtech-Java-Runoob:Java 循环结构 - for, while 及 do...while 1.返回顶部 1. Java 循环结构 - for, while 及 do...whil ...