linux awk命令怎么用?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux awk命令怎么用?相关的知识,希望对你有一定的参考价值。
参考技术A linux awk命令怎么用? awk:用于一行中分成数个“栏位”来处理。适合处理 小型资料。执行模式:awk '条件型别1动作1 条件型别2动作2 ...' filename
# last | awk 'print $1 "\t" $3' <== 检视登入者的资料,只显示登入名和ip地址,并以[tab]隔开
awk 的内建变数
变数名称 代表的含义
NF 每一行($0)拥有的栏位总数
NR 当前 awk 所处理的是 “第几行” 资料
FS 当前分隔符,预设空格键
awk 的逻辑运算子
运算单元 代表含义
> 大于
< 小于
>= 大于或等于
<= 小于或等于
== 等于
!= 不等于
范例:
cat /etc/passwd | awk 'FS=":" $3 < 10 print $1 "\t" $3' <== 档案/etc/passwd是以":"分隔的,检视第三栏小于10的资料,并且只显示帐号与第三栏
以上是我对awk的总结,希望对你有帮助,是我写的哦,不是复制的。
linux 怎么用awk命令 取出一段文字
awk '/<DIMENSION NAME="CCCCCC" SRC_TYPE="INTERNAL">/,/<DIMENSIONS>/ print $0' filename
Linux awk命令问题
head -n 3 /etc/passwd|awk -F ':' '$1="root"' 这里$1="root",表示将第1列的值赋值为root,因此上述命令表示:将/etc/passwd中前3行按照‘:’分隔后第一列以root显示,并列印其他列。
awk -F ':' '$3=="0"' /etc/passwd
这里$3=="0",表示将第三列与"0”进行匹配,以什么方式匹配呢?以‘:’分隔后的第三列进行匹配并列印。这里是匹配列印,所以列印的是匹配的那一行(被:分隔后),而不是显示分隔后的列。
所以,区别在于一个是分隔后赋值列印分隔后列的值,一个是按照指定分隔方式进行匹配找到匹配的行,列印的是匹配的那一行。
linux的awk命令问题
一行里 第一个元素和第三个元素
linux下 awk命令问题
1、其实这样基本满足要求。但是确实不够严谨。试试是否可以。
ps -le | grep sshd | awk 'print $4'
2、对ps 命令用的最多的是ps -ef 对el 我不是很了解具体输出什么。当然,是不是你压根就没有这个sshd服务启动。这些都先验证一下。一步一步的输出,看看问题出现在管道的哪一个环节。
3、或者这个 $14==sshd 栏位你指定错了。 awk $指定的变数是从1 开始的。$0是整个行。这个不要忘记了哦。
如果上述1第一种情况可以输出,第二种2不可以话,可能就验证了我的假设。你栏位拆解出现错误。把$14 这个栏位好好看看。
linux awk命令基础 怎么在终端写
awk一般用于文字处理,通常用作资料提取。终端书写demo
awk 'print ' info.txt
以上是输出文字档案info.txt的所有内容,请使用实际档案进行替换info.txt
ps -ef|grep process_name | awk -F"" 'print $2'
以上是查询process_name程序的ID资讯,把查询资讯作为引数传给awk进行过滤,请使用实际程序名替换process_name。
awk命令在 linux和aix下的区别
三种呼叫awk的命令方式:
1.命令列方式:awk [-F field-separator] 'mands' input-file(s)
-F选项可选:awk -F: 'mands' input-file
2.将所有的awk命令插入一个档案,并是awk程式可执行,然后用awk命令直译器作为指令码的首行,
以便通过键入指令码名称来呼叫它。
3.将所有的awk命令插入一个单独档案,然后呼叫:
awk -f awk-script-file input-files(s)
-f:指明在档案awk-script-file中的awk指令码
input-file(s):使用awk进行浏览的档名。
awk指令码
在命令中呼叫awk时,awk指令码由各种操作和模式组成。
-F,awk每次读一条记录或一行,并使用指定的分隔符分分隔指定域;
所没分隔符,则使用空格。
任何awk语句都由模式和动作组成
模式,决定动作语句何时触发及触发事件,若忽略模式部分,动作将时刻保持执行状态。
模式,可是任何条件语句,或符合语句,或正则表示式。
BEGIN:设定计数,列印头,在任何文字浏览动作之前;
END:用来在awk完成档案浏览动作后列印输出档案总数和结尾状态标志。
动作,在内指定;大多用来列印;里面可包含:if,looping,回圈推出结构;
若不指明采取动作,awk将列印所有浏览出来的记录。
如何在Linux中使用awk命令
awk例项
1、cat /etc/passwd|awk -F: 'print $1'
2、linux的awk一般都是gawk,/bin/awk -> gawk
3、awk ‘/abc/’ file.txt 显示档案中包含abc行。类似grep abc a.txt
4、awk ‘print NR,NF,$1,$NF,’ file.txt按空格分隔列,显示当前记录号、域数和每一行的第一列和最后一列。
-F引数可以设定分割引数,例如按:分割
awk -F: ‘print $1’ /etc/passwd
或者cat file|awk -F “|” ‘print $1’
5、awk程式语言
cat v.txt|awk ‘print length($1)’
6、awk中使用NR和FNR,一般在awk处理多个档案时,NR==FNR才有意义
NF 当前记录中的栏位数。
NR 当前记录数。
FNR同NR,但相对于当前档案。
awk ‘print NR,FNR’ test.txt test2.txt
awk ‘if(NR==FNR)a[FNR]=$1;elseprint $1,a[FNR]’ b.txt a.txt
7、列印奇数行与偶数行
awk ‘NR%2’ test.txt
awk ‘!(NR%2)’ test.txt
8、杀死tomcat的s.sh指令码
#!/bin/sh
ps -ef| grep tomcat |grep -v grep | awk ‘print $2’ |xargs kill -9
9、列印前7列
cat a.txt|awk ‘NF=71’ >> b.txt
tail -f aess.log|awk ‘NF=7′ OFS=’\t’ >> b.txt
cut -d”,” -f3-6 urfile
LINUX系统怎么使用awk命令实现下述操作
cat file|awk -F"name=" 'print $2'|awk -F\" 'print $1'
试试看,第二个”的转义,我没测试,可以自己调下
linux awk 内置变量使用介绍
参考技术A 一、内置变量表属性
说明
$0
当前记录(作为单个变量)
$1~$n
当前记录的第n个字段,字段间由FS分隔
FS
输入字段分隔符
默认是空格
NF
当前记录中的字段个数,就是有多少列
NR
已经读出的记录数,就是行号,从1开始
RS
输入的记录他隔符默
认为换行符
OFS
输出字段分隔符
默认也是空格
ORS
输出的记录分隔符,默认为换行符
ARGC
命令行参数个数
ARGV
命令行参数数组
FILENAME
当前输入文件的名字
IGNORECASE
如果为真,则进行忽略大小写的匹配
ARGIND
当前被处理文件的ARGV标志符
CONVFMT
数字转换格式
%.6g
ENVIRON
UNIX环境变量
ERRNO
UNIX系统错误消息
FIELDWIDTHS
输入字段宽度的空白分隔字符串
FNR
当前记录数
OFMT
数字的输出格式
%.6g
RSTART
被匹配函数匹配的字符串首
RLENGTH
被匹配函数匹配的字符串长度
SUBSEP
34
2、实例
1、常用操作
代码如下:
[chengmo@localhost
~]$
awk
'/^root/print
$0'
/etc/passwd
root:x:0:0:root:/root:/bin/bash
/^root/
为选择表达式,$0代表是逐行
2、设置字段分隔符号(FS使用方法)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":"/^root/print
$1,$NF'
/etc/passwd
root
/bin/bash
FS为字段分隔符,可以自己设置,默认是空格,因为passwd里面是”:”分隔,所以需要修改默认分隔符。NF是字段总数,$0代表当前行记录,$1-$n是当前行,各个字段对应值。
3、记录条数(NR,FNR使用方法)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":"print
NR,$1,$NF'
/etc/passwd
1
root
/bin/bash
2
bin
/sbin/nologin
3
daemon
/sbin/nologin
4
adm
/sbin/nologin
5
lp
/sbin/nologin
6
sync
/bin/sync
7
shutdown
/sbin/shutdown
……
NR得到当前记录所在行
4、设置输出字段分隔符(OFS使用方法)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":";OFS="^^"/^root/print
FNR,$1,$NF'
/etc/passwd
1^^root^^/bin/bash
OFS设置默认字段分隔符
5、设置输出行记录分隔符(ORS使用方法)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":";ORS="^^"print
FNR,$1,$NF'
/etc/passwd
1
root
/bin/bash^^2
bin
/sbin/nologin^^3
daemon
/sbin/nologin^^4
adm
/sbin/nologin^^5
lp
/sbin/nologin
从上面看,ORS默认是换行符,这里修改为:”^^”,所有行之间用”^^”分隔了。
6、输入参数获取(ARGC
,ARGV使用)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":";print
"ARGC="ARGC;for(k
in
ARGV)
k"="ARGV[k];
'
/etc/passwd
ARGC=2
0=awk
1=/etc/passwd
ARGC得到所有输入参数个数,ARGV获得输入参数内容,是一个数组。
7、获得传入的文件名(FILENAME使用)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINFS=":";print
FILENAMEprint
FILENAME'
/etc/passwd
/etc/passwd
FILENAME,$0-$N,NF
不能使用在BEGIN中,BEGIN中不能获得任何与文件记录操作的变量。
8、获得linux环境变量(ENVIRON使用)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINprint
ENVIRON["PATH"];'
/etc/passwd
/usr/lib/qt-3.3/bin:/usr/kerberos/bin:/usr/lib/ccache:/usr/lib/icecc/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbi
n:/usr/java/jdk1.5.0_17/bin:/usr/java/jdk1.5.0_17/jre/bin:/usr/local/mysql/bin:/home/web97/bin
ENVIRON是子典型数组,可以通过对应键值获得它的值。
9、输出数据格式设置:(OFMT使用)
代码如下:
[chengmo@localhost
~]$
awk
'BEGINOFMT="%.3f";print
2/3,123.11111111;'
/etc/passwd
0.667
123.111
OFMT默认输出格式是:%.6g
保留六位小数,这里修改OFMT会修改默认数据输出格式。
10、按宽度指定分隔符(FIELDWIDTHS使用)
复制代码
代码如下:
[chengmo@localhost
~]$
echo
20100117054932
|
awk
'BEGINFIELDWIDTHS="4
2
2
2
2
3"print
$1"-"$2"-"$3,$4":"$5":"$6'
2010-01-17
05:49:32
FIELDWIDTHS其格式为空格分隔的一串数字,用以对记录进行域的分隔,FIELDWIDTHS="4
2
2
2
2
2"就表示$1宽度是4,$2是2,$3是2
....
。这个时候会忽略:FS分隔符。
11、RSTART
RLENGTH使用
代码如下:
[chengmo@localhost
~]$
awk
'BEGINstart=match("this
is
a
test",/[a-z]+$/);
start,
RSTART,
RLENGTH
'
11
11
4
[chengmo@localhost
~]$
awk
'BEGINstart=match("this
is
a
test",/^[a-z]+$/);
start,
RSTART,
RLENGTH
'
0
0
–1
RSTART
被匹配正则表达式首位置,RLENGTH
匹配字符长度,没有找到为-1.
以上是:awk的一些内置变量使用,希望有什么问题可以与我交流。
以上是关于linux awk命令怎么用?的主要内容,如果未能解决你的问题,请参考以下文章