成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Awk 命令的多種用法,你知道幾個?

系統 Linux
在本文中,我們將看看這個簡單的用法以及 awk 可以為你做的其他事情,并通過足夠的示例向您展示該命令比想象的要靈活得多。

awk 命令提供的不僅僅是從輸入字符串中選擇字段,還包括提取數據列、打印簡單文本、評估內容——甚至進行數學運算。

如果只在需要從文本行中選擇特定字段時才使用 awk,你可能會錯過該命令可以提供的許多其他用處。在本文中,我們將看看這個簡單的用法以及 awk 可以為你做的其他事情,并通過足夠的示例向您展示該命令比想象的要靈活得多。

提取數據列

awk 提供的最簡單的用法是從文件或通過管道傳輸到它的數據中選擇特定字段。默認使用空格作為字段分隔符:

[root@localhost ~]# echo one two three four five | awk '{print $4}'
four
[root@localhost ~]# who | awk '{print $1}'
root
root

在上面顯示的命令中,awk 僅從提供的數據中提取第四個字段和第一個字段。

awk 還可以通過在 awk 命令后添加文件名來從文件中提取文本。

[root@localhost ~]# awk -F ':' '{print "user: "$1,"home: "$6,"shell: "$NF}' /etc/passwd

圖片

在這種情況下,awk 使用-F ':'選項指定 冒號 作為分隔符。選出了文本中的第一列、第六列和最后一列。

命令中的 $NF? 選擇最后一個字段。這是因為 NF 表示一行中的字段數,而$NF 表示最后一個字段的值。

字段可以按你認為有用的任何順序打印。在此示例中,我們正在重新排列 date 命令輸出中的字段。

[root@localhost ~]# date | awk '{print "Date:",$6,$2,$3}'
Date: 2021 Sep 26

圖片

如果你希望輸出由其他符號來做分隔符,你可以使用 OFS(輸出字段分隔符)指定輸出分隔符,如下所示:

[root@localhost ~]# date | awk '{OFS="-"; print $6,$2,$3}'
2021-Sep-26

圖片

評估內容

還可以使用 awk 評估字段。例如,如果只想在 /etc/passwd 文件中列出UID大于1000的用戶信息:

[root@localhost ~]# awk -F ':' '$3 >= 1000' /etc/passwd
nobody:x:65534:65534:Kernel Overflow User:/:/sbin/nologin
user01:x:1000:1000::/home/user01:/bin/bash
test01:x:1001:1001::/home/test01:/bin/bash
natasha:x:1002:1002::/home/natasha:/bin/bash

圖片

如果要為列表添加標題,可以添加 BEGIN 子句,如果標題想要多行,可以使用\n換行符:

[root@localhost ~]# awk -F ':' 'BEGIN {print "user accounts\n=============="} $3 >= 1000' /etc/passwd
user accounts
==============
nobody:x:65534:65534:Kernel Overflow User:/:/sbin/nologin
user01:x:1000:1000::/home/user01:/bin/bash
test01:x:1001:1001::/home/test01:/bin/bash
natasha:x:1002:1002::/home/natasha:/bin/bash

圖片

用awk做數學計算

awk 提供了算數能力,可以計算平方根、對數、切線等。

[root@localhost ~]# awk 'BEGIN {print sqrt(2021)}'
44.9555
[root@localhost ~]# awk 'BEGIN {print log(2019)}'
7.61036

圖片

編寫 awk 腳本

還可以使用 awk 編寫獨立腳本。這是一個模仿前面提供的示例之一的示例,但也計算了系統上擁有帳戶的用戶數。

[root@localhost ~]# vim list_users
#!/usr/bin/awk -f
# This line is a comment

BEGIN {
printf "%s\n","User accounts:"
print "=============="
FS=":"
n=0
}

# Now we'll run through the data
{
if ($3 >= 1000) {
print $1
n ++
}
}

END {
print "=============="
print n " accounts"
}

圖片

請注意,僅在腳本啟動時運行的 BEGIN 部分,提供標題、指示字段分隔符并設置從 0 開始的計數器。該腳本還包括一個 END 部分,該部分僅在腳本最后運行。

[root@localhost ~]# ./list_users /etc/passwd
User accounts:
==============
nobody
systemd-coredump
systemd-resolve
polkitd
sssd
chrony
unbound
user01
test01
natasha
==============
10 accounts

圖片

計算文件中的行數

要使用 awk 打印文件中的行數,請執行以下操作:

[root@localhost ~]# awk 'END {print NR}' /etc/passwd
26

圖片

命令中包含 END 意味著在處理行之后提供輸出。NR(記錄數)表示文件中的行數。

獲取最常使用的命令

還可以將 awk 與許多其他命令一起使用,以查看在當前歷史文件里面你最常使用的命令。

[root@localhost ~]# history | awk '{print $2}'|sort|uniq -c|sort -nr|head -5
58 lvs
48 ll
31 vim
29 vgs
29 df

圖片

? 圖片 ?

責任編輯:武曉燕 來源: Linux就該這么學
相關推薦

2023-10-31 08:23:54

網絡命令Linux

2020-05-14 08:13:56

JDK命令Java

2022-02-15 07:26:31

Ncat工具Linux

2025-03-25 10:49:13

2019-08-27 08:02:03

Linux內存占用命令

2023-10-30 18:00:00

Docker命令開源平臺

2024-03-01 13:48:00

Git配置系統

2021-11-04 11:54:30

Linux內存系統

2024-11-08 17:04:03

Linux運維

2021-03-12 10:12:09

etState函數React

2023-04-27 08:15:09

2024-01-18 00:16:07

2021-10-12 09:20:02

數據庫SQL腳本

2021-02-27 17:13:21

前端代碼邏輯

2023-11-26 00:26:00

2023-05-30 14:54:17

Python循環語句工具

2021-10-14 06:52:47

算法校驗碼結構

2022-04-13 10:05:48

網關Flowable事件訂閱

2019-06-03 08:04:43

Apache服務器命令

2023-11-30 12:03:06

linuxAwk
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日日草夜夜草 | 国产精品视频一 | 无码一区二区三区视频 | 久久久一区二区 | 日韩中文欧美 | 国产精品久久久久久久久久久久久 | 欧美日韩国产在线观看 | 久久成人18免费网站 | 精品国产欧美日韩不卡在线观看 | 欧美男人天堂 | 羞羞的视频网站 | 欧美日韩国产在线观看 | av免费观看在线 | 国产精品免费在线 | 大久 | 国产a区 | 性一爱一乱一交一视频 | 狠狠综合久久av一区二区小说 | 视频精品一区二区三区 | 精品视频在线播放 | 野狼在线社区2017入口 | 日韩在线免费视频 | 国产精品久久久 | 黄色在线观看网站 | 日本午夜网站 | 欧美日韩成人影院 | 色.com| 亚洲深夜福利 | 五月天综合影院 | 国产精品大片 | 久久69精品久久久久久国产越南 | 中文字幕在线看第二 | 色橹橹欧美在线观看视频高清 | 狠狠色狠狠色综合系列 | 日本精品在线观看 | 国产成人精品久久二区二区91 | 亚洲精品一 | 大久| 欧美日韩不卡在线 | 99久久精品免费看国产四区 | 国产黄色精品在线观看 |