点击上方“

     生信科技爱好者

     ”,马上关注

    真爱,请置顶或星标

    

作者:ghostwu

原文:https://www.cnblogs.com/ghostwu/p/9085653.html

AWK 中,变量分为两种:内置变量与自定义变量。

内置变量

常见的内置变量有:

  • FS:输入字段分隔符, 默认为空白字符;

  • OFS:输出字段分隔符, 默认为空白字符;

  • RS:输入记录分隔符(输入换行符), 指定输入时的换行符;

  • ORS:输出记录分隔符(输出换行符),输出时用指定符号代替换行符;

  • NF:number of Field,当前行的字段的个数(即当前行被分割成了几列),字段数量;

  • NR:行号,当前处理的文本行的行号;

  • FNR:各文件分别计数的行号;

  • FILENAME:当前文件名;

  • ARGC:命令行参数的个数;

  • ARGV:数组,保存的是命令行所给定的各参数。

1. NF 打印字段数

下面的 NF 打印出每行有多少列。

$ awk '{print NF}' ghostwu.txt 
2
$ cat ghostwu.txt 
ghostwu
zhangsan 22
lisi 23 woman

2. 引用 NF 变量

引用 NF 变量,需要用美元符号。

$ cat ghostwu.txt 
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman
$ awk '{print $NF}' ghostwu.txt 
man
woman
woman
$ awk '{print $(NF-2), $(NF-1), $(NF)}' ghostwu.txt 
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman

3. NR 打印行号

使用 NR 打印每一行的行号:

$ awk '{print NR,$0}' ghostwu.txt 
1 ghostwu 20 man
2 zhangsan 22 woman
3 lisi 23 woman

4. NR 与 FNR

awk 支持多文件扫描,如果采用 NR,下一个文件的行序号会接着上一个文件;如果使用 FNR,就会单独统计。

$ awk '{print NR, $0}' ghostwu.txt ghostwu.bak 
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman
$ awk '{print FNR, $0}' ghostwu.txt ghostwu.bak 
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman

5. RS 指定行分隔符

RS 指定行输入符,默认为回车换行,如果我们想让它以空格作为行输入符( 即,遇到空格就换行 ),当我们指定使用空格作为"行分隔符"时,在 awk 解析文本时,每当遇到空格,awk 就认为遇到的空格是换行符,于是 awk 就将文本换行了。

$ awk '{print NR, $0}' ghostwu.txt 
ghostwu 20 man
zhangsan 22 woman
lisi 23 woman
$ awk -v RS=" " '{print NR, $0}' ghostwu.txt
ghostwu
20
man
zhangsan
22
woman
lisi
23
woman

6. ORS 指定输出行分隔符

ghostwu@dev:~/linux/awk$ awk -v ORS='---->' '{print $0}' ghostwu.txt 
ghostwu 20 man---->zhangsan 22 woman---->lisi 23 woman---->ghostwu@dev:~/linux/awk$ 

7. 同时指定输入,输出行分隔符

$ awk -v RS=" " -v ORS='->' '{print $0}' ghostwu.txt
ghostwu->20->man
zhangsan->22->woman
lisi->23->woman

8. 使用 FILENAME 打印文件名称

$ awk '{print FILENAME, NR, $0}' ghostwu.txt ghostwu.bak
ghostwu.txt 1 ghostwu 20 man
ghostwu.txt 2 zhangsan 22 woman
ghostwu.txt 3 lisi 23 woman
ghostwu.bak 4 ghostwu 20 man
ghostwu.bak 5 zhangsan 22 woman
ghostwu.bak 6 lisi 23 woman

9. ARGV 保存命令行参数的数组

ARGV 保存命令行参数的数组,'pattern{action}'并不被看做参数。

$ awk '{print ARGV[0], ARGV[1], ARGV[2]}' ghostwu.txt 
awk ghostwu.txt 
awk ghostwu.txt 
awk ghostwu.txt 

10. ARGC 保存命令行参数个数

使用 ARGC 可以保存命令行参数的个数,下例中ARGV[1]没有值,因为命令行没有给第三个参数。

$ awk '{print ARGV[0], ARGV[1], ARGV[2], ARGC}' ghostwu.txt 
awk ghostwu.txt  2
awk ghostwu.txt  2
awk ghostwu.txt  2

自定义变量

awk 常见的用户自己定义的变量,有两种形式:通过 -v 变量名的形式,和在 program 中直接定义。

1. -v varname=value

使用-v varname=value的形式自定义变量时, 变量名区分字符大小写。

$ awk -v my_name="hello world" 'BEGIN{print my_name}'
hello world

2. 在 program 中直接定义变量

在 program 中直接定义变量时,以下定义了3个自定义变量,其实形式像编程语言一样,定义的时候用分号。打印变量跟之前一样,用逗号隔开,注意,不需要用美元符号。

$ awk 'BEGIN{ my_name="zhangsan"; my_age=22; my_sex="男"; print my_name, my_age, my_sex}'
zhangsan 22 男

3. 引用命令行定义的变量

除了 1、2 的自定义变量方式外,我们也可以引用命令行定义的变量。

$ echo $myvar

$ myvar="我在命令行定义的变量"
$ awk -v var1=$myvar 'BEGIN{print var1}'
我在命令行定义的变量


END—

声明:本公众号所有转载的文章仅用于参考学习使用,文章包括文字与图片在内的著作权属于原作者所有,禁止用于商用。文章任何形式的转载请联系原作者获得授权。

戳原文,更有料!

本文分享自微信公众号 - 生信科技爱好者(bioitee)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

awk 内置变量与自定义变量的更多相关文章

  1. awk内置函数、外部变量

    外部变量 ①获取外部变量 格式: awk '{action}' 变量名=变量值 ,这样传入变量可以在action中获得值. 示例: test='awk test'--day-5 外部变量 ①获取外部变 ...

  2. Linux常用基本命令:三剑客命令之-awk内置变量与自定义变量

    AWK中,变量分为两种:内置变量与自定义变量. 常见的内置变量有: FS:输入字段分隔符, 默认为空白字符 OFS:输出字段分隔符, 默认为空白字符 RS:输入记录分隔符(输入换行符), 指定输入时的 ...

  3. 【转】awk内置变量

    awk是个优秀文本处理工具,可以说是一门程序设计语言.下面是awk内置变量. 一.内置变量表 属性 说明 $0 当前记录(作为单个变量) $1~$n 当前记录的第n个字段,字段间由FS分隔 FS 输入 ...

  4. Linux基础教程 linux awk内置变量使用介绍

    awk是个优秀文本处理工具,可以说是一门程序设计语言.下面是兄弟连Linux培训 给大家介绍的awk内置变量. 一.内置变量表 属性 说明 $0 当前记录(作为单个变量) $1~$n 当前记录的第n个 ...

  5. awk 内置变量

    awk 内置变量 FS 设置输入域分隔符,等价于命令行 -F选项 OFS 输出域分隔符 NF 浏览记录的域的个数NR 已读的记录数RS 控制记录分隔符 ORS 输出记录分隔符 substr 截取指定的 ...

  6. 『忘了再学』Shell基础 — 29、AWK内置变量

    目录 1.AWK内置变量 2.练习说明 (1)$n变量练习 (2)FS变量练习 (3)NF变量和NR变量练习 3.总结: 1.AWK内置变量 AWK内置变量如下表: awk内置变量 作用 $0 代表目 ...

  7. Thymeleaf 之 内置对象、定义变量、URL参数及标签自定义属性

    Thymeleaf 之 内置对象.定义变量.URL参数及标签自定义属性 本文章来自[知识林] 如标题所述,这篇文章主要讲述Thymeleaf中的内置对象(list解析.日期格式化.数字格式化等).定义 ...

  8. linux awk 内置函数详细介绍(实例)

    这节详细介绍awk内置函数,主要分以下3种类似:算数函数.字符串函数.其它一般函数.时间函数 一.算术函数: 以下算术函数执行与 C 语言中名称相同的子例程相同的操作: 函数名 说明 atan2( y ...

  9. linux awk 内置函数实例

    awk内置函数,主要分4种:算数函数.字符串函数.时间函数.一般函数 一.算术函数 以下算术函数执行与 C 语言中名称相同的子例程相同的操作: 函数名 说明 atan2( y, x ) 返回 y/x ...

  10. linux awk 内置函数详细介绍(实例)

    这节详细介绍awk内置函数,主要分以下3种类似:算数函数.字符串函数.其它一般函数.时间函数 一.算术函数: 以下算术函数执行与 C 语言中名称相同的子例程相同的操作: 函数名 说明 atan2( y ...

随机推荐

  1. Prometheus Operator 与 kube-prometheus 之一-简介

    简介 Prometheus Operator Prometheus Operator: 在 Kubernetes 上管理 Prometheus 集群.该项目的目的是简化和自动化基于 Prometheu ...

  2. Centos 6 部署PPTP服务

    前言:PPTP使用一个TCP连接对隧道进行维护,使用通用路由封装(GRE)技术把数据封装成PPP数据桢通过隧道传送.可以对封装PPP桢中的负载数据进行加密或压缩. 注意:PPTP协议已经被IOS系统所 ...

  3. MySQL 更新执行的过程

    更多内容,前往 IT-BLOG Select语句的执行过程会经过连接器.分析器.优化器.执行器.存储引擎,同样的 Update语句也会同样走一遍 Select语句的执行过程. ​ 但是和 Select ...

  4. Docker部署nginx+vue项目并运行

    一.打包VUE项目 npm run build:prod 二.编写default.conf 文件 server { listen 80; server_name localhost; #charset ...

  5. 浅学git工具

    1.git工具介绍及使用 git工具直接安装: 直接运行exe文件进行安装,按默认的操作点击下一步就行了 校验: 在DOS命令行中输入:git  --version 如果能正常显示出对应的版本就是ok ...

  6. .net6的IIS发布部署

    1.打开控制面板,打开程序 2.点击启动或关闭windows功能 3.在其中选择要设置的IIS功能 4.重启IIS服务 5.发布项目 6.在开始菜单搜索IIS,点击IIS管理器 7.右击网站,点击添加 ...

  7. SpringBoot中如何实现业务校验,这种方式才叫优雅!

    大家好,我是飘渺. 在日常的接口开发中,为了保证接口的稳定安全,我们一般需要在接口逻辑中处理两种校验: 参数校验 业务规则校验 首先我们先看看参数校验. 参数校验 参数校验很好理解,比如登录的时候需要 ...

  8. MySQL四种日志binlog/redolog/relaylog/undolog

    优质博文:IT-BLOG-CN 一.binlog binlog记录数据库表结构和表数据变更,比如update/delete/insert/truncate/create,它不会记录select.存储着 ...

  9. Android Banner - ViewPager 02

    Android Banner - ViewPager 02 现在来给viewpager实现的banenr加上自动轮播 自动轮播的原理,使用handler的延迟消息来实现. 自动轮播实现如下内容 开始轮 ...

  10. Charlotte Holmes series

    Charlotte Holmes Novel The charactors are adorable. Jamie and Charlotte are a very cute couple. More ...