awk基本用法及举例

查询文件空行所在的行号

[root@tyzz ~]# awk '{if ($0~/^$/)print NR}' test 
3
6
8
[root@tyzz ~]# grep -n ^$ test      
3:
6:
8:
[root@tyzz ~]# grep -n ^$ test |tr ":" " "
3 
6 
8

统计排序

awk -F "/" '{print $3}' domain.txt |sort |uniq -c |sort -nr
基本用法
[root@tyzz ~]# awk -F ':' '{print $3,$4}' 1.txt 
0 0
1 1
2 2
3 4
4 7
5 0
6 0
7 0
8 12
11 0

以:为分隔符 分段 输出 第三段 第四段 输出文本的分隔符 由OFS=" " 指定

[root@tyzz ~]# awk -F ':' 'OFS="#" {print $3,$4}' 1.txt 
0#0
1#1
2#2
3#4
4#7
5#0
6#0
7#0
8#12
11#0
[root@tyzz ~]#

匹配单个

[root@tyzz ~]# awk '/root/' 1.txt 
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

匹配多个 用 | 连接

[root@tyzz ~]# awk '/root|mail/' 1.txt 
root:x:0:0:root:/root:/bin/bash
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
[root@tyzz ~]# awk -F ':' '$1=="root"' 1.txt 
root:x:0:0:root:/root:/bin/bash

NR 指定行数

[root@tyzz ~]# awk -F ':' 'NR=10 {print $1,$7}' 1.txt 
root /bin/bash
bin /sbin/nologin
daemon /sbin/nologin
adm /sbin/nologin
lp /sbin/nologin
sync /bin/sync
shutdown /sbin/shutdown
halt /sbin/halt
mail /sbin/nologin
operator /sbin/nologin

加if

[root@tyzz ~]# awk -F ':' 'OFS="#" {if(NR==5) print $1,$7}' 1.txt 
lp#/sbin/nologin

以:为分隔符 可以分多少段 NF

[root@tyzz ~]# awk -F ':' '{print NF}' 1.txt 
7
7
7
[root@tyzz ~]# awk -F ':' 'OFS="==";$7=$3+$4' 1.txt 
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
bin==x==1==1==bin==/bin==2
daemon:x:2:2:daemon:/sbin:/sbin/nologin
daemon==x==2==2==daemon==/sbin==4
adm:x:3:4:adm:/var/adm:/sbin/nologin

转载于:https://www.cnblogs.com/aallenn/p/6700586.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: AWK是一种流行的编程语言,它可以用来处理文本文件,并在Unix、Linux、Windows和Mac OS系统中使用。它是一种强大的文本处理工具,可以用来搜索、分析、排序和复制文本文件。举个例子,可以用awk命令打印出一个文本文件中的特定字段,例如:awk -F ":" '{print $2}' /etc/passwd。 ### 回答2: 在Shell中,awk是一种强大的文本处理工具,用于在文本文件中逐行读取并进行数据处理和分析。它可以根据指定的规则进行文本匹配、提取、替换、计算等操作。 awk基本语法是由模式(pattern)和操作(action)组成的。当模式与当前行匹配时,对应的操作将被执行。如果没有指定模式,那么默认匹配所有行。 以下是一些awk的使用示例: 1. 提取文件中特定列的数据: 假设有一个文件data.txt,每一行的数据由空格分隔,按照从左到右的顺序包括姓名、年龄和性别。可以使用awk命令提取其中的姓名列: ```shell awk '{print $1}' data.txt ``` 这样将打印出data.txt中每一行的姓名。 2. 进行数学计算: 假设有一个包含数值数据的文件numbers.txt,每一行一个数字。现在想要计算所有数字的总和,可以使用awk实现: ```shell awk '{sum += $1} END {print sum}' numbers.txt ``` 这样将打印出numbers.txt中所有数字的总和。 3. 替换文本中的特定字符串: 假设有一个文本文件text.txt,其中包含多个“apple”字符串,现在想要将其中的所有“apple”替换为“orange”,可以使用awk实现: ```shell awk '{gsub("apple", "orange")} 1' text.txt ``` 这样将输出替换后的文本。 通过以上示例,可以看出awk在Shell中的含义是对文本进行强大的处理和分析,并且他具有很多其他强大的功能,如使用正则表达式进行模式匹配等。 ### 回答3: awk是一种文本处理工具,在shell脚本中经常被使用,它使用一种类似于C语言的语法来处理文本数据。awk的名称是由计算机科学家Alfred Aho、Peter Weinberger和Brian Kernighan的姓氏首字母组成的。 awk的主要作用是根据特定的规则对文本进行匹配、提取和处理,它逐行扫描文件,并根据用户定义的规则(即正则表达式)执行相应的操作。 以下是一个使用awk的简单例子,假设有一个包含学生姓名和成绩的文本文件students.txt,其格式如下: ``` Alice 85 Bob 90 Cathy 75 Daniel 82 ``` 我们可以使用awk命令来读取该文件并输出成绩大于80的学生姓名: ```shell awk '{if($2 > 80) print $1}' students.txt ``` 运行以上命令后,输出结果如下: ``` Alice Bob Daniel ``` 在这个例子中,awk首先读取students.txt文件。然后,它对每一行进行处理,使用空格作为分隔符将每行划分为多个字段。变量$1表示第一个字段(学生姓名),$2表示第二个字段(学生成绩)。 在awk命令中,我们使用if语句来判断成绩是否大于80,若满足条件则输出学生姓名。通过这种方式,我们可以根据不同的需求对文本进行灵活的处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值