精通awk系列(9):修改字段或NF引起的$0重新计算
2024-09-01 21:40:39
回到:
修改字段或NF值的联动效应
注意下面的分割和计算两词:分割表示使用FS(field Separator),计算表示使用预定义变量OFS(Output Field Separator)。
- 修改
$0
,将使用FS
重新分割字段,所以会影响$1、$2...
- 修改
$1、$2
,将根据$1
到$NF
等各字段来重新计算$0
- 即使是
$1 = $1
这样的原值不变的修改,也一样会重新计算$0
- 即使是
- 为不存在的字段赋值,将新增字段并按需使用空字符串填充中间的字段,并使用
OFS
重新计算$0
awk 'BEGIN{OFS="-"}{$(NF+2)=5;print $0}' a.txt
- 增加NF值,将使用空字符串新增字段,并使用
OFS
重新计算$0
awk 'BEGIN{OFS="-"}{NF+=3;print $0}' a.txt
- 减小NF值,将丢弃一定数量的尾部字段,并使用
OFS
重新计算$0
awk 'BEGIN{OFS="-"}{NF-=3;print $0}' a.txt
关于$0
当读取一条record之后,将原原本本地被保存到$0
当中。
awk '{print $0}' a.txt
换句话说,没有导致$0
重建,$0
就一直是原原本本的数据,所以指定OFS也无效。
awk 'BEGIN{OFS="-"}{print $0}' a.txt # OFS此处无效
当$0
重建后,将自动使用OFS重建,所以即使没有指定OFS,它也会采用默认值(空格)进行重建。
awk '{$1=$1;print $0}' a.txt # 输出时将以空格分隔各字段
awk '{print $0;$1=$1;print $0}' OFS="-" a.txt
如果重建$0
之后,再去修改OFS,将对当前行无效,但对之后的行有效。所以如果也要对当前行生效,需要再次重建。
# OFS对第一行无效
awk '{$4+=10;OFS="-";print $0}' a.txt
# 对所有行有效
awk '{$4+=10;OFS="-";$1=$1;print $0}' a.txt
关注$0
重建是一个非常有用的技巧。
例如,下面通过重建$0
的技巧来实现去除行首行尾空格并压缩中间空格:
$ echo " a b c d " | awk '{$1=$1;print}'
a b c d
$ echo " a b c d " | awk '{$1=$1;print}' OFS="-"
a-b-c-d
最新文章
- miniui
- iOS学习之判断是否有网络的方法
- arcgis制作兴趣点分布图
- Neo4j 查询已经创建的索引与约束
- ACM/ICPC 之 并查集-食物链(POJ1182)
- Jmeter—6 CSV Data Set Config 通过文件导入数据
- Firefox SVG getBBox方法返回'NS_ERROR_FAILURE'错误分析
- C#&;java重学笔记(函数)
- CentOS设置服务开机启动的方法
- 常用的css的技巧
- think straight系列读书笔记之《暗时间》
- 关于cocos2d这个东西
- 提升PHP速度的53个建议
- C# winfrom 模拟ftp文件管理
- android L新控件RecyclerView具体解释DeMo
- css3布局属性flex
- 必须知道的Java八大排序算法
- 使用IDEA部署项目到远程服务器
- phpcms 路由配置
- ES6知识整理(8)--Promise对象