首頁 php教程 PHP开发 關於awk指令的幾個內建變數(NF,NR,FS,FILENAME)

關於awk指令的幾個內建變數(NF,NR,FS,FILENAME)

Dec 15, 2016 am 11:40 AM
awk命令

1.NF:支持记录域个数,在记录被读之后再设置例1

[root@redhat wilsontest]# pwd

/tmp/wilsontest

[root@redhat wilsontest]# echo $PWD | awk -F / '{print $NF}'

wilsontest

这里取得的是当前目录的最后一个文件的名字。

再如:

[root@redhat wilsontest]# echo "/usr/local/etc/rc.sybase" | awk -F / '{print $NF}'

rc.sybase

-F /表示以’/’分开域

2.NR:已经读取的记录数3.FILENAME

定义:支持a w k脚本实际操作的输入文件。因为a w k可以同时处理许多文件,因此如果访问了这个变量,将告之系统目前正在浏览的实际文件。

例如:

[root@redhat wilsontest]# cat filetest

hello wilson

world

linux

oracle

C++

[root@redhat wilsontest]# awk '{print NF,NR,$0}END{print FILENAME}' filetest

2 1 hello wilson

1 2 world

1 3 linux

1 4 oracle

1 5 C++

说明:第一列NF输出读取记录的域的个数;NR表示已经读取的记录数;$0实际就是把记录输出出来;FILENAME就是输出正在处理的文件。

为了说明FILENAME的作用,再做如下操作:

[root@redhat wilsontest]# cp filetest filetest.bak

[root@redhat wilsontest]# ls -la

total 28

drwxr-xr-x  2 root root 4096 Oct 26 10:02 .

drwxrwxrwt 11 root root 4096 Oct 26 09:46 ..

-rw-r--r--  1 root root   36 Oct 26 10:00 filetest

-rw-r--r--  1 root root   36 Oct 26 10:02 filetest.bak

-rw-r--r--  1 root root 4617 Oct 23 09:10 man.config

[root@redhat wilsontest]# awk '{print NF,NR,$0}END{print FILENAME}' filetest filetest.bak

2 1 hello wilson

1 2 world

1 3 linux

1 4 oracle

1 5 C++

2 6 hello wilson

1 7 world

1 8 linux

1 9 oracle

1 10 C++



学习awk时,一定要记得动手去实践,只有在实践中才能发现问题,以下就我在学习中和实践中的经验,总结一下RS,ORS,FS,OFS的区别和联系。

一,RS与ORS

1,RS是记录分隔符,默认的分隔符是\n,具体用法看下

[root@krlcgcms01 mytest]# cat test1     //测试文件
111 222  
333 444  
555 666
登入後複製
[root@krlcgcms01 mytest]# awk '{print $0}' test1  //awk 'BEGIN{RS="\n"}{print $0}' test1 这二个是一样的
111 222  
333 444  
555 666
登入後複製

上面test1文件里的内容理解为,111 222\n333 444\n555 6666,利用\n进行分割。看下一个例子

3,自定义RS分割符

[zhangy@localhost test]$ echo"111 222|333 444|555 666"|awk 'BEGIN{RS="|"}{print $0,RT}'
111 222 |  
333 444 |  
555 666
登入後複製

结合上面一个例子,就很容易理解RS的用法了。

4,RS也可能是正则表达式

[zhangy@localhost test]$ echo"111 222a333 444b555 666"|awk 'BEGIN{RS="[a-z]+"}{print $1,RS,RT}'
111 [a-z]+ a  
333 [a-z]+ b  
555 [a-z]+
登入後複製

从例3和例4,我们可以发现一点,当RT是利用RS匹配出来的内容。如果RS是某个固定的值时,RT就是RS的内容。

5,RS为空时

[zhangy@localhost test]$ cat -n test2  
1  111 222  
2  
3  333 444  
4  333 444  
5  
6  
7  555 666  
[zhangy@localhost test]$ awk 'BEGIN{RS=""}{print $0}' test2  
111 222  
333 444  
333 444  
555 666  
[zhangy@localhost test]$ awk &#39;BEGIN{RS="";}{print "<",$0,">"}&#39; test2  //这个例子看着比较明显
< 111 222 >  
< 333 444     //这一行和下面一行,是一行
333 444 >  
< 555 666 >
登入後複製

从这个例子,可以看出当RS为空时,awk会自动以多行来做为分割符。

6,ORS记录输出分符符,默认值是\n

把ORS理解成RS反过程,这样更容易记忆和理解,看下面的例子。

[zhangy@localhost test]$ awk &#39;BEGIN{ORS="\n"}{print $0}&#39; test1  //awk &#39;{print $0}&#39; test1二者是一样的
111 222  
333 444  
555 666  
[zhangy@localhost test]$ awk &#39;BEGIN{ORS="|"}{print $0}&#39; test1  
111 222|333 444|555 666|
登入後複製

二,FS与OFS

1,FS指定列分割符

[zhangy@localhost test]$ echo"111|222|333"|awk &#39;{print $1}&#39;
111|222|333  
[zhangy@localhost test]$ echo"111|222|333"|awk &#39;BEGIN{FS="|"}{print $1}&#39;
111
登入後複製

,FS也可以用正则

[zhangy@localhost test]$ echo"111||222|333"|awk &#39;BEGIN{FS="[|]+"}{print $1}&#39;
111
登入後複製

,FS为空的时候

[zhangy@localhost test]$ echo"111|222|333"|awk &#39;BEGIN{FS=""}{NF++;print $0}&#39;
1 1 1 | 2 2 2 | 3 3 3
登入後複製

当FS为空的时候,awk会把一行中的每个字符,当成一列来处理。

4,RS被设定成非\n时,\n会成FS分割符中的一个

[zhangy@localhost test]$ cat test1  
111 222  
333 444  
555 666  
[zhangy@localhost test]$ awk &#39;BEGIN{RS="444";}{print $2,$3}&#39; test1  
222 333  
666
登入後複製

222和333之间是有一个\n的,当RS设定成444后,222和333被认定成同一行的二列了,其实按常规思想是二行的一列才对。

5,OFS列输出分隔符

[zhangy@localhost test]$ awk &#39;BEGIN{OFS="|";}{print $1,$2}&#39; test1  
111|222  
333|444  
555|666  
[zhangy@localhost test]$ awk &#39;BEGIN{OFS="|";}{print $1 OFS $2}&#39; test1  
111|222  
333|444  
555|666
登入後複製

test1只有二列,如果100列,都写出来太麻烦了吧。

[zhangy@localhost test]$ awk &#39;BEGIN{OFS="|";}{print $0}&#39; test1  
111 222  
333 444  
555 666  
[zhangy@localhost test]$ awk &#39;BEGIN{OFS="|";}{NF=NF;print $0}&#39; test1  
111|222  
333|444  
555|666
登入後複製



更多关于awk命令的几个内置变量(NF,NR,FS,FILENAME)相关文章请关注PHP中文网!


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)