awk中使用shell变量

其实在awk里,是不能直接使用shell变量的 
方法是:awk -v 选项让awk 里使用shell变量 
TIME=60 
awk -v time="$TIME" ‘BEGIN{FS="|"} {if ($7>time) print $2 }‘ 
这样要注意:在awk里,time不能加$符号。

网上说如下方法都可行:

一:"‘$var‘"

这种写法大家无需改变用‘括起awk程序的习惯,是老外常用的写法.如:

var="test" 
awk ‘BEGIN{print "‘$var‘"}‘

这种写法其实际是双括号变为单括号的常量,传递给了awk.

如果var中含空格,为了shell不把空格作为分格符,便应该如下使用:

var="this is a test" 
awk ‘BEGIN{print "‘"$var"‘"}‘ 
二:‘"$var"‘

这种写法与上一种类似.如果变量含空格,则变为‘""$var""‘较为可靠. 
三.把括起awk程序的‘‘变为"",使用"$var"

如: 
$var="this is a test" 
awk ‘BEGIN{print "$var"}" 
这是因为在""里$是特殊字符,而在‘‘里$是普通字符. 
四:export 变量,使用ENVIRON["var"]形式,

如: 
$var="this is a test";export $var 
awk ‘BEGIN{print ENVIRON["var"]}‘ 
五:当然也可以使用-v选项

如: 
$var="this is a test" 
awk -v nvar="$var" ‘{print nvar}‘

这样便把系统变量定义成了awk变量.

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

awk读取shell中的变量
可以使用-v选项实现功能
$b=1
$cat f
apple

$awk -v var=$b ‘{print var, $var}‘ f
1 apple

除了使用-v选项外,还可以使用"‘$variable‘"的方式从shell往awk传递变量(注意:这里是单引号)
$awk ‘{print $b, ‘$b‘}‘ f
apple 1

如果变量含空格,则变为‘""$var""‘较为可靠.

至于有没有办法把awk中的变量传给shell呢,这个问题我是这样理解的。shell调用awk实际上是fork一个子进程出来,而子进程是无法向父进程传递变量的,除非用重定向(包括管道)
$a=$(awk ‘{print $b, ‘$b‘}‘ f)
$echo $a
apple 1

附1:http://bbs.chinaunix.net/thread-1381166-1-1.html

附2:http://www.cnblogs.com/mydomain/archive/2012/09/24/2699467.html

时间: 2024-10-13 01:24:41

awk中使用shell变量的相关文章

awk中匹配shell变量字符

遇到问题: 现在有两个脚本,我想 将file1中的内容按file2来匹配 [[email protected] home]# cat file1 3-1-1 POTV=1,POTA=0,POTP=2 1-4-76 POTV=1,POTA=0,POTP=1 2-1-2 POTV=1,POTA=1,POTP=1 3-1-4 POTV=1,POTA=1,POTP=2 4-1-5 POTV=1,POTA=1,POTP=2 7-1-2 POTV=1,POTA=1,POTP=2 3-1-10 POTV=1,

在awk代码中引用shell变量的方法

一个香栗子胜过千言万语 #!/bin/bash foo="Good" # 不带空格 bar="Hello World" # 带空格 awk 'BEGIN { print "'$foo'"; "'"$bar"'" }' 上面的栗子中,保持了用单引号把awk代码包围起来的惯例. 在awk代码中引用shell变量时, 使用一对双引号,内嵌一对单引号, 再在这一对内层单引号里面按$var(适用于不含空格的shell

sed中引入shell变量

sed中引入shell变量的四种方法1.eval sed 's/$a/$b/' filename2.sed "s/$a/$b/" filename3.sed 's/'$a'/'$b'/' filename 4.sed s/$a/$b/ filename

精通awk系列(14):细说awk中的变量和变量赋值

回到: Linux系列文章 Shell系列文章 Awk系列文章 awk变量 awk的变量是动态变量,在使用时声明. 所以awk变量有3种状态: 未声明状态:称为untyped类型 引用过但未赋值状态:unassigned类型 已赋值状态 引用未赋值的变量,其默认初始值为空字符串或数值0. 在awk中未声明的变量称为untyped,声明了但未赋值(只要引用了就声明了)的变量其类型为unassigned. gawk 4.2版提供了typeof()函数,可以测试变量的数据类型,包括测试变量是否声明.

Linux下如何让 awk 使用 Shell 变量

当我们编写 shell 脚本时,我们通常会在脚本中包含其它小程序或命令,例如 awk 操作.对于 awk 而言,我们需要找一些将某些值从 shell 传递到 awk 操作中的方法.那么如何让 awk 使用 Shell 变量呢?兄弟连Linux培训接下来为大家介绍一下: 有两种可能的方法可以让 awk 使用 shell 变量: 1. 使用 Shell 引用 让我们用一个示例来演示如何在一条 awk 命令中使用 shell 引用来替代一个 shell 变量.在该示例中,我们希望在文件 /etc/pa

awk中的变量

awk中的变量定义非常简单,只需要给出一个变量名并且赋予适当的值即可. awk中的常规变量分为两种类型:字符串和数值.无需指定变量类型,awk会根据变量所处的环境自动判断.如果没有指定值,数值类型的变量默认等于0,字符串类型的变量默认为空. awk中的系统内置变量总结如下,有一点要事先说明:awk说明中,记录表示一个样本,字段表示特征. 变量 说明 $0 记录变量,表示当前正在处理的记录,整条记录作为一个字符串 $n 字段变量,n可以为1,2,...表示第几个字段(特征) NF 整数值,表示当前

【译】 AWK教程指南 6在AWK程序中使用Shell命令

awk程序中允许调用Shell指令,并提供管道解决awk与系统间数据传递的问题.所以awk很容易使用系统资源,读者可利用这个特点来编写某些适用的系统工具. 范例:写一个awk程序来打印出线上人数. 将下列程序建文件,命名为 count.awk BEGIN { while ( "who" | getline ) n++ print n } 并执行下列命令: $ awk -f count.awk 执行结果将会打印出目前在线人数. 说 明: 1. awk 程序并不一定要处理数据文件,以本例而

Shell、Awk 中自动隐式类型转换的“坑”

1.问题: 在林林总总的编程语言里,弱类型的语言着实不少,一方面这种"动态类型"用起来很方便,而另一方面则"坑"你没商量~ 常见的 SQL.Shell.Awk 都会遇到各种暗藏的"隐式类型转换",下面就列举一些 shell.awk 里的自动隐式类型转换 case,防止掉坑. 注意 shell.awk 的变量为空 字符串.变量为空 未定义.初始值的隐式转换问题: # shell 下的字典排序比较 [email protected] 10:59:23

awk中可以使用system来执行复杂的shell命令

在awk中可以直接执行shell命令. [plain] view plain copy [email protected]:~$ touch a [email protected]:~$ touch b [email protected]:~$ cat a.txt a b [email protected]:~$ awk '{cmd="rm "$0;system(cmd)}' a.txt [email protected]:~$ ls a.txt      dd