awk命令1
[root@a ~]# awk 'END{print NR}' c.txt #没错,这就是文件的行数,当然,这种统计方法不是linux下最快的,但也是一种思路
3
[root@a ~]# wc -l c.txt #这种统计方法是linux下最快的
3 c.txt
[root@a ~]# head -3 /etc/passwd
root:a:0:0:root:/root:/bin/bash
bin:b:1:1:bin:/bin:/sbin/nologin
daemon:c:2:2:daemon:/sbin:/sbin/nologin
[root@a ~]# head -3 /etc/passwd | awk -F':' '{print $1}'
root
bin
daemon
[root@a ~]# head -3 /etc/passwd | awk -F':' '{print $2}'
a
b
c
[root@a ~]#head -3 /etc/passwd | awk -F':' '{print $1}{print $2}'
root
a
bin
b
daemon
c
#有两个print,可以看到第二列放到了第一列之后换行显示
[root@a ~]# head -3 /etc/passwd | awk -F':' '{print $1,"\n",$2}'
root
a
bin
b
daemon
c
#在print中将$1和$2之间加一个\n,第二列前的空白字符也被输出了,两者还是有所区别
[root@a ~]# head -5 /etc/passwd | awk -F: '{if(NR>2&&NR<5)print NR,$0}'
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
4 adm:x:3:4:adm:/var/adm:/sbin/nologin
#awk条件语句,打印整行信息并显示打印行号,if语句位置在{ }中间
awk -F':' '$1~/root/' 1.txt
root:x:0:0:root:/root:/bin/bash
111root222:x:0:0:root:/root:/sbin/nologin
awk -F':' '$1~/root/{OFS="#";print $1,$2,$3}' 1.txt
root#x#0
111root222#x#0
awk -F':' '$1=="root"{print$1,$2,$3}' 1.txt
root x 0
awk -F':' '$1=="root" || NR>=30{print $1,$2}' 1.txt
root x
rpc x
111
awk -F':' 'NF>3&&NR<3{print $1,$2,$3}' 1.txt
root x 0
111root222 x 0
~为模糊匹配,==表示精确匹配
awk -F: '$3>=1000&&NF=="/bin/bash"{print $1,$NF}' /etc/passwd
#打印系统中能够正常登陆的普通用户
echo “one tow three four” |awk '{print $(NF-2)}'
two
#awk支持四则运算
awk ‘{print $2+20 >> "b.txt"}’ a.txt
#可以通过awk命令将结果重定向输出到b.txt文件
[root@a ~]# awk -F':' 'NF>3&&NR>16{print NR,"\t",$3,$5}' /etc/passwd
17 89
18 74 Privilege-separated SSH
打印符合条件的内容并显示行号,awk模式支持关系表达式
awk -F':' '$1~”root“{print $0}' 1.txt
#OFS用于输出时指定字段分隔符,后跟“;”接后续命令
awk -F':' '$1=="root"{print $1,$2}' 1.txt
awk -F':' '$1=="root"||NR>=30{print $1,$2}' 1.txt
awk -F':' 'NF>3 &&NR<4{print $1,$2,$3}' 1.txt
#列数(NF)大于3列,行数(NR)小于4行
匹配
awk -F: '/root/{print}' a.txt
awk -F: '/root/' a.txt
awk -F: '/^root/' a.txt
awk -F: '/bash$' a.txt
其他语句
awk -F':' '{if($3<10){print "USER=>"$1}} a.txt
awk -F':' '{printf "USERNAME:%-10s %15s\n",$1,$NF}' a.txt
实例:
1、过滤网卡的ip地址
注意:通过BEGIN{FS="[ :]+"}指定字段分隔符,其中BEGIN和END模块必需写在' '内部,如果是if条件表达式也必需写在' '中间,格式为'{if(条件){命令……}}‘
2、指定字段加20重定向到新的文件
awk通过变量查看文件行数
注意:a++等价于a=a+1,a++表示先赋值后加1。
awk命令1的更多相关文章
- linux awk命令详解
linux awk命令详解 简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分 ...
- awk命令详解
搜索 纠正错误 添加实例 awk 文本和数据进行处理的编程语言 补充说明 awk 是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入(stdin).一个或多个文件 ...
- Linux安全基础:awk命令的使用
awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...
- AWK命令学习
使用方法 awk 'pattern {action}' {filenames} 尽管操作可能会很复杂,但语法总是这样,其中 pattern 表示 AWK 在数据中查找的内容,而 action 是在找到 ...
- awk 命令
awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...
- AWK命令的用法
1.awk命令简介: awk是一种可以处理数据.产生格式化报表的语言,功能十分强大. awk的工作方式是读取数据,将每一行数据视为一条记录(record)每笔记录以字段分隔符分成若干字段,然后输出各个 ...
- [Linux] linux awk命令详解
reference : http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2858470.html 简介 awk是一个强大的文本分析工具,相对于g ...
- awk命令简单介绍
简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再 ...
- Linux的awk命令
简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再 ...
- awk命令--update20150120
简介 awk是一个强大的文本分析工具,把文件逐行读入,以空格为默认分隔符分割成field,切开的部分再进行各种分析处理. 模式和动作: 任何awk语句都是由模式和动作组成,模式部分决定动作语句何时触发 ...
随机推荐
- sql server 三角函数
正弦函数SIN(x)和反正弦函数ASIN(x) --SIN(x)返回x的正弦,其中x为弧度值 --ASIN(x)返回x的反正弦,即正弦x的值,若x不在-1到1的范围内,则返回NULL 示例:selec ...
- C#解决并发的设计思路
解决并发的方案,应用场景,一个报名的方法,可是要限制报名的人数:一,如果是单机版,就是部署一个服务器站点的我们可以使用很经典的lock锁,或者queue队列,针对单机版二,如果是部署了集群的站点1&g ...
- java复习(2)
1.函数的重载:在同一个类中,允许存在一个以上的同名函数,只要他们的参数个数或者参数类型不相同就可以. 重载与返回值类型无关,只看参数列表.重载方便阅读,优化了程序的设计 eg://返回两个 整数值的 ...
- composer之predis
安装: composer require predis/predis 即可 predis是PHP连接Redis的操作库,由于它完全使用php编写,大量使用命名空间以及闭包等功能,只支持php5 ...
- vue.js(1)--创建vue实例的基本结构
vue实例基本结构与MVVM框架 (1)vue实例基本结构 <!DOCTYPE html> <html lang="en"> <head> &l ...
- 62. Unique Paths (JAVA)
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
- .关于oracle中varchar2的最大长度
关于 varchar2 的最大长度varchar2有两个最大长度:一个是在字段类型4000:一个是在PL/SQL中变量类型32767.这是一个比较容易出错的地方.因为在函数中可以声明长度超过4000的 ...
- RHEL6查看运行级别和grub加密阻止进入单用户模式
1.查看当前运行级别 [root@cluster01 ~]# cat /etc/redhat-release Red Hat Enterprise Linux Server release 6.5 ( ...
- python2 'ascii'编码问题
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 223: ordinal not in range(128) ...
- 最简单的Android项目
这是我在windows环境下,试验过的最简单Android项目,只用记事本和命令行即可完成. 环境准备 开发环境需要Java SDK(官网下载),Android SDK(官网下载). 首先安装Java ...