新聞中心
在Linux系統(tǒng)中有許多命令可以用來過濾,比如:awk命令、sed命令、head 命令等等,在本篇文章中重點為大家講解這些命令的使用方法,有需要的小伙伴可以參考一下。

為屏邊等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及屏邊網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為網(wǎng)站建設、網(wǎng)站設計、屏邊網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
img
1、 awk 命令
awk 是一個卓越的模式掃描和處理語言,它可被用于在 Linux 下構(gòu)造有用的過濾器。你可以通過閱讀我們的 awk 系列 1 到 13 部分 來開始使用它。
另外,也可以通過閱讀 awk 的 man 手冊來獲取更多的信息和使用選項。
$ man awk
2、 sed 命令
sed 是一款過濾和轉(zhuǎn)換文本的強大的流編輯器。我們已經(jīng)寫了兩篇關(guān)于 sed 的有用的文章,你可以通過這兒來了解:
-
如何使用 GNU sed 命令在 Linux 下創(chuàng)建、編輯和處理文件
-
日常 Linux 系統(tǒng)管理員任務使用的 15 個有用的 sed 命令小貼士和技巧
sed 的 man 手冊已經(jīng)添加控制選項和說明:
$ man sed
3、 grep、 egrep、 fgrep、 rgrep 命令行
這些過濾器輸出匹配指定模式的行。它們從一個文件或者標準輸入讀取行,并且輸出所有匹配的行,默認輸出到標準輸出。
注意:主程序是 grep,這些變體與使用特定的選項的 grep 相同,如下所示(為了向后兼容性,它們依舊在使用):
$ egrep = grep -E
$ fgrep = grep -F
$ rgrep = grep -r
下面是一些基本的 grep 命令:
tecmint@TecMint ~ $ grep "aaronkilik" /etc/passwd
aaronkilik:x:1001:1001::/home/aaronkilik:
tecmint@TecMint ~ $ cat /etc/passwd | grep "aronkilik"
aaronkilik:x:1001:1001::/home/aaronkilik:
在 Linux 下的 grep、 egrep 和 fgrep 的差異?中,你可以了解更多。
4、 head 命令
head 用于顯示文件前面的部分,默認情況下它輸出前 10 行。你可以使用 -n 標志來指定顯示的行數(shù):
tecmint@TecMint ~ $ head /var/log/auth.log
Jan 2 10:45:01 TecMint CRON[3383]: pam_unix(cron:session): session opened for user root by (uid=0)
Jan 2 10:45:01 TecMint CRON[3383]: pam_unix(cron:session): session closed for user root
Jan 2 10:51:34 TecMint sudo: tecmint : TTY=unknown ; PWD=/home/tecmint ; USER=root ; COMMAND=/usr/lib/linuxmint/mintUpdate/checkAPT.py
Jan 2 10:51:34 TecMint sudo: pam_unix(sudo:session): session opened for user root by (uid=0)
Jan 2 10:51:39 TecMint sudo: pam_unix(sudo:session): session closed for user root
Jan 2 10:55:01 TecMint CRON[4099]: pam_unix(cron:session): session opened for user root by (uid=0)
Jan 2 10:55:01 TecMint CRON[4099]: pam_unix(cron:session): session closed for user root
Jan 2 11:05:01 TecMint CRON[4138]: pam_unix(cron:session): session opened for user root by (uid=0)
Jan 2 11:05:01 TecMint CRON[4138]: pam_unix(cron:session): session closed for user root
Jan 2 11:09:01 TecMint CRON[4146]: pam_unix(cron:session): session opened for user root by (uid=0)
tecmint@TecMint ~ $ head -n 5 /var/log/auth.log
Jan 2 10:45:01 TecMint CRON[3383]: pam_unix(cron:session): session opened for user root by (uid=0)
Jan 2 10:45:01 TecMint CRON[3383]: pam_unix(cron:session): session closed for user root
Jan 2 10:51:34 TecMint sudo: tecmint : TTY=unknown ; PWD=/home/tecmint ; USER=root ; COMMAND=/usr/lib/linuxmint/mintUpdate/checkAPT.py
Jan 2 10:51:34 TecMint sudo: pam_unix(sudo:session): session opened for user root by (uid=0)
Jan 2 10:51:39 TecMint sudo: pam_unix(sudo:session): session closed for user root
學習如何 使用帶有 tail 和 cat 命令的 head 命令,以便在 Linux 下更有效的使用。
5、 tail 命令
tail 輸出一個文件的后面的部分(默認 10 行)。使用 -n 選項來指定顯示的行數(shù)。
下面的命令將會輸出指定文件的最后 5 行:
tecmint@TecMint ~ $ tail -n 5 /var/log/auth.log
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on 0.0.0.0 port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on :: port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Received SIGHUP; restarting.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on 0.0.0.0 port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on :: port 22.
另外,tail 有一個特殊的選項 -f ,可以 實時查看一個文件的變化 (尤其是日志文件)。
下面的命令將會使你能夠監(jiān)控指定文件的變化:
tecmint@TecMint ~ $ tail -f /var/log/auth.log
Jan 6 12:58:01 TecMint sshd[1269]: Server listening on :: port 22.
Jan 6 12:58:11 TecMint sshd[1269]: Received SIGHUP; restarting.
Jan 6 12:58:12 TecMint sshd[1269]: Server listening on 0.0.0.0 port 22.
Jan 6 12:58:12 TecMint sshd[1269]: Server listening on :: port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Received SIGHUP; restarting.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on 0.0.0.0 port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on :: port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Received SIGHUP; restarting.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on 0.0.0.0 port 22.
Jan 6 13:01:27 TecMint sshd[1269]: Server listening on :: port 22.
閱讀 tail 的 man 手冊,獲取使用選項和說明的完整內(nèi)容:
$ man tail
6、 sort 命令
sort 用于將文本文件或標準輸入的行進行排序。
下面是一個名為 domain.list 的文件的內(nèi)容:
tecmint@TecMint ~ $ cat domains.listtecmint.comtecmint.comnews.tecmint.comnews.tecmint.comlinuxsay.comlinuxsay.comwindowsmint.comwindowsmint.com
你可以像這樣運行一個簡單的 sort 命令 來排序文件內(nèi)容:
tecmint@TecMint ~ $ sort domains.listlinuxsay.comlinuxsay.comnews.tecmint.comnews.tecmint.comtecmint.comtecmint.comwindowsmint.comwindowsmint.com
你可以有多種方式來使用 sort 命令,請參閱以下一些關(guān)于 sort 命令的有用的文章。
-
Linux 的 ‘sort’命令的14個有用的范例(一)
-
Linux 的 ‘sort’命令的七個有趣實例(二)
-
如何基于修改日期和時間來查找和排序文件
7、 uniq 命令
uniq 命令用于報告或者忽略重復行,它從標準輸入過濾行,并且把結(jié)果寫到標準輸出。
在對一個輸入流運行 sort 之后,你可以使用 uniq 刪除重復行,如下例所示。
為了顯示行出現(xiàn)的數(shù)目,使用 -c 選項,要在對比時忽略大小寫的差異,使用 -i 選項:
tecmint@TecMint ~ $ cat domains.listtecmint.comtecmint.comnews.tecmint.comnews.tecmint.comlinuxsay.comlinuxsay.comwindowsmint.comtecmint@TecMint ~ $ sort domains.list | uniq -c 2 linuxsay.com2 news.tecmint.com2 tecmint.com1 windowsmint.com
通過閱讀 uniq 的 man 手冊來獲取進一步的使用信息和選項:
$ man uniq
8、 fmt 命令行
fmt 是一款簡單的優(yōu)化的文本格式化器,它重新格式化指定文件的段落,并且打印結(jié)果到標準輸出。
以下是從文件 domain-list.txt 提取的內(nèi)容:
1.tecmint.com 2.news.tecmint.com 3.linuxsay.com 4.windowsmint.com
為了把上面的內(nèi)容重新格式化成一個標準的清單,運行下面的命令,使用 -w 選項定義最大行寬度:
tecmint@TecMint ~ $ cat domain-list.txt1.tecmint.com 2.news.tecmint.com 3.linuxsay.com 4.windowsmint.comtecmint@TecMint ~ $ fmt -w 1 domain-list.txt1.tecmint.com2.news.tecmint.com3.linuxsay.com4.windowsmint.com
9、 pr 命令
pr 命令轉(zhuǎn)換文本文件或者標準輸入之后打印出來。例如在 Debian 系統(tǒng)上,你可以像下面這樣顯示所有的安裝包:
$ dpkg -l
為了將要打印的列表在頁面和列中組織好,使用以下命令。
tecmint@TecMint ~ $ dpkg -l | pr --columns 3 -l 20 2017-01-06 13:19 Page 1Desired=Unknown/Install ii adduser ii apg| Status=Not/Inst/Conf- ii adwaita-icon-theme ii app-install-data|/ Err?=(none)/Reinst-r ii adwaita-icon-theme- ii apparmor||/ Name ii alsa-base ii apt+++-=================== ii alsa-utils ii apt-cloneii accountsservice ii anacron ii apt-transport-httpsii acl ii apache2 ii apt-utilsii acpi-support ii apache2-bin ii apt-xapian-indexii acpid ii apache2-data ii aptdaemonii add-apt-key ii apache2-utils ii aptdaemon-data2017-01-06 13:19 Page 2ii aptitude ii avahi-daemon ii bind9-hostii aptitude-common ii avahi-utils ii binfmt-supportii apturl ii aview ii binutilsii apturl-common ii banshee ii bisonii archdetect-deb ii baobab ii bltii aspell ii base-files ii blueberryii aspell-en ii base-passwd ii bluetoothii at-spi2-core ii bash ii bluezii attr ii bash-completion ii bluez-cupsii avahi-autoipd ii bc ii bluez-obexd.....
其中,使用的標志如下:
-
–column 定義在輸出中創(chuàng)建的列數(shù)。
-
-l 指定頁面的長度(默認是 66 行)。
10、 tr 命令行
這個命令從標準輸入轉(zhuǎn)換或者刪除字符,然后輸出結(jié)果到標準輸出。
使用 tr 的語法如下:
$ tr options set1 set2
看一下下面的例子,在第一個命令,set1( [:upper:] ) 代表指定輸入字符的大小寫(都是大寫字符)。 set2([:lower:]) 代表期望結(jié)果字符的大小寫。第二個例子意思相似,轉(zhuǎn)義字符 /n 表示在新的一行打印輸出:
tecmint@TecMint ~ $ echo "WWW.TECMINT.COM" | tr [:upper:] [:lower:]www.tecmint.comtecmint@TecMint ~ $ echo "news.tecmint.com" | tr [:lower:] [:upper:]NEWS.TECMINT.COM
11、 more 命令
more 命令是一個有用的文件過濾器,最初為查看證書而建。它一頁頁顯示文件內(nèi)容,用戶可以通過按回車來顯示更多的信息。
你可以像這樣使用它來顯示大文件:
tecmint@TecMint ~ $ dmesg | more[ 0.000000] Initializing cgroup subsys cpuset[ 0.000000] Initializing cgroup subsys cpu[ 0.000000] Initializing cgroup subsys cpuacct[ 0.000000] Linux version 4.4.0-21-generic (buildd@lgw01-21) (gcc version 5.3.1 20160413 (Ubuntu 5.3.1-14ubuntu2) ) #37-Ubuntu SMP Mon Apr 18 18:33:37 UTC 2016 (Ubuntu 4.4.0-21.37-generic4.4.6)[ 0.000000] Command line: BOOT_IMAGE=/boot/vmlinuz-4.4.0-21-generic root=UUID=bb29dda3-bdaa-4b39-86cf-4a6dc9634a1b ro quiet splash vt.handoff=7[ 0.000000] KERNEL supported cpus:[ 0.000000] Intel GenuineIntel[ 0.000000] AMD AuthenticAMD[ 0.000000] Centaur CentaurHauls[ 0.000000] x86/fpu: xstate_offset[2]: 576, xstate_sizes[2]: 256[ 0.000000] x86/fpu: Supporting XSAVE feature 0x01: 'x87 floating point registers'[ 0.000000] x86/fpu: Supporting XSAVE feature 0x02: 'SSE registers'[ 0.000000] x86/fpu: Supporting XSAVE feature 0x04: 'AVX registers'[ 0.000000] x86/fpu: Enabled xstate features 0x7, context size is 832 bytes, using 'standard' format.[ 0.000000] x86/fpu: Using 'eager' FPU context switches.[ 0.000000] e820: BIOS-provided physical RAM map:[ 0.000000] BIOS-e820: [mem 0x0000000000000000-0x000000000009d3ff] usable[ 0.000000] BIOS-e820: [mem 0x000000000009d400-0x000000000009ffff] reserved[ 0.000000] BIOS-e820: [mem 0x00000000000e0000-0x00000000000fffff] reserved[ 0.000000] BIOS-e820: [mem 0x0000000000100000-0x00000000a56affff] usable[ 0.000000] BIOS-e820: [mem 0x00000000a56b0000-0x00000000a5eaffff] reserved[ 0.000000] BIOS-e820: [mem 0x00000000a5eb0000-0x00000000aaabefff] usable--More--
12、 less 命令
less 是和上面的 more 命令相反的一個命令,但是它提供了額外的特性,而且對于大文件,它會更快些。
按照 more 命令相同的方式使用它:
tecmint@TecMint ~ $ dmesg | less
[ 0.000000] Initializing cgroup subsys cpuset
[ 0.000000] Initializing cgroup subsys cpu
[ 0.000000] Initializing cgroup subsys cpuacct
[ 0.000000] Linux version 4.4.0-21-generic (buildd@lgw01-21) (gcc version 5.3.1 20160413 (Ubuntu 5.3.1-14ubuntu2) ) #37-Ubuntu SMP Mon Apr 18 18:33:37 UTC 2016 (Ubuntu 4.4.0-21.37-generic
4.4.6)
[ 0.000000] Command line: BOOT_IMAGE=/boot/vmlinuz-4.4.0-21-generic root=UUID=bb29dda3-bdaa-4b39-86cf-4a6dc9634a1b ro quiet splash vt.handoff=7
[ 0.000000] KERNEL supported cpus:
[ 0.000000] Intel GenuineIntel
[ 0.000000] AMD AuthenticAMD
[ 0.000000] Centaur CentaurHauls
[ 0.000000] x86/fpu: xstate_offset[2]: 576, xstate_sizes[2]: 256
[ 0.000000] x86/fpu: Supporting XSAVE feature 0x01: 'x87 floating point registers'
[ 0.000000] x86/fpu: Supporting XSAVE feature 0x02: 'SSE registers'
[ 0.000000] x86/fpu: Supporting XSAVE feature 0x04: 'AVX registers'
[ 0.000000] x86/fpu: Enabled xstate features 0x7, context size is 832 bytes, using 'standard' format.
[ 0.000000] x86/fpu: Using 'eager' FPU context switches.
[ 0.000000] e820: BIOS-provided physical RAM map:
[ 0.000000] BIOS-e820: [mem 0x0000000000000000-0x000000000009d3ff] usable
[ 0.000000] BIOS-e820: [mem 0x000000000009d400-0x000000000009ffff] reserved
[ 0.000000] BIOS-e820: [mem 0x00000000000e0000-0x00000000000fffff] reserved
[ 0.000000] BIOS-e820: [mem 0x0000000000100000-0x00000000a56affff] usable
[ 0.000000] BIOS-e820: [mem 0x00000000a56b0000-0x00000000a5eaffff] reserved
[ 0.000000] BIOS-e820: [mem 0x00000000a5eb0000-0x00000000aaabefff] usable
:
學習為什么 Linux 下進行有效的文件瀏覽, ‘less’ 比 ‘more’ 命令更快。
基本上就這些了,如果你還知道其他本文沒有提供的 Linux 下有用的文本過濾命令行工具,可以在下面的評論部分通知我們。
本文標題:詳解Linux過濾命令
地址分享:http://www.dlmjj.cn/article/ccodcoo.html


咨詢
建站咨詢
