博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
awk 以列为域提取文件内容
阅读量:7290 次
发布时间:2019-06-30

本文共 1539 字,大约阅读时间需要 5 分钟。

文件内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
[root@hxy tmp]
# cat file
[aa]
aa1
dd2
dd3
dd4
 
[bb]
dd5
dd6
dd7
xx8
dd9
 
[cc]
ee2
334
ghdfg7
uuu
ooo7
sdsd
ggg
gogo
pp[
gggs
ssss
jjjj
aaaa

我现在的需求是提取出[bb] 到[cc]之间的所有行

1
2
3
4
5
6
[bb]
dd5
dd6
dd7
xx8
dd9
1
2
3
4
5
6
7
[root@hxy tmp]
# awk -v RS= '/^\[bb]/' file
[bb]
dd5
dd6
dd7
xx8
dd9

这个怎么理解呢?

-v 大家度知道是指定变量的

所以这个-v一是同样的指定了RS=

等于空就是默认的输入分隔符为'\n'既是空行

so我们这里的文件就会被分为3行了

1
2
3
4
[root@hxy tmp]
# awk -v RS= '{print $1,$2,$3,$4,$5,$6,$7}' file
[aa] aa1 dd2 dd3 dd4
[bb] dd5 dd6 dd7 xx8 dd9
[cc] ee2 334 ghdfg7 uuu ooo7 sdsd

这样是不是好理解多了,我想打印哪一行就打印哪一行就行了

1
2
3
4
5
6
7
[root@hxy tmp]
# awk -v RS= 'NR==2 {print}' file
[bb]
dd5
dd6
dd7
xx8
dd9

这里的 NR==2 {print} 和 /^\[aa]/ 是同样的结果

第一个是明确了打印第二行

第二个是匹配[aa]然后打印[aa]所在的行,达到同样的结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[root@hxy tmp]
# awk -v RS= 'NR==2,NR==3 {print}' file
[bb]
dd5
dd6
dd7
xx8
dd9
[cc]
ee2
334
ghdfg7
uuu
ooo7
sdsd
ggg
gogo
pp[
gggs
ssss
jjjj
aaaa

这样打印出来的是第二个域到第三个域之间的结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
[root@hxy tmp]
# awk -v RS= 'NR==1,NR==3 {print}' file
[aa]
aa1
dd2
dd3
dd4
[bb]
dd5
dd6
dd7
xx8
dd9
[cc]
ee2
334
ghdfg7
uuu
ooo7
sdsd
ggg
gogo
pp[
gggs
ssss
jjjj
aaaa

而这样打印的是第一个域到第三个域之间的结果

如果我只想打印第一域和第三域呢?

[root@hxy tmp]# awk -v RS= 'NR==1;NR==3 {print}' file

[aa]

aa1

dd2

dd3

dd4

[cc]

ee2

334

ghdfg7

uuu

ooo7

sdsd

ggg

gogo

pp[

gggs

ssss

jjjj

aaaa

这样就行了.

如果有其他的要求,在干要求改就行了到此实验结束.

本文转自  Forande  51CTO博客,原文链接:http://blog.51cto.com/853056088/1932477

转载地址:http://sgcjm.baihongyu.com/

你可能感兴趣的文章
C# 使用Log4Net记录日志(基础篇)
查看>>
转 比较跨语言通讯框架:Apache Thrift和Google Protobuf
查看>>
push代码到github
查看>>
证书是如何打通信任链的?
查看>>
OSS 性能测试经验总结
查看>>
JavaScript权威设计--JavaScript类型,值,变量(简要学习笔记三)
查看>>
解决无法找到"txfile:platformres:msgmgr\msgmgr.htm"
查看>>
【原创】Windows下使用 Eclipse 管理 RabbitMQ 源码之问题解决
查看>>
继LINQ动态组合查询PredicateExtensions讲解
查看>>
[MySQL学习] Innodb change buffer(1)之初识篇
查看>>
页面图层显示顺序
查看>>
数据结构——队列
查看>>
MySQL内核月报 2014.08-MySQL· 捉虫动态·long semaphore waits
查看>>
linux 目录操作函数
查看>>
DT科技评论:第1期(创刊号)
查看>>
Linux 克隆虚拟机引起的“Device eth0 does not seem to be present, delaying initialization”
查看>>
android-async-http框架源码分析
查看>>
【Oracle】v$表和v_$同义词的访问权限
查看>>
用了 CSDN 的 markdown 编辑器吐槽下~~
查看>>
MariaDB newest alpha version Features short VS PostgreSQL 9.3
查看>>