AWK中的OFS的问题

echo a b c d |awk ‘{OFS = ":";print $0}‘
  我的理解是应该把输出显示为如下的方式
  a:b:c:d
  dan但执行的结果不是这样的
  a b c d
  为什么啊
  echo a b c d|awk ‘{print $1":"$2":"$3":"$4}‘
  或者
  echo a b c d|awk ‘BEGIN {OFS=":"}{print $1,$2,$3,$4}‘
  或
  echo a b c d|awk ‘{OFS=":";print $1,$2,$3,$4}‘
  这个方法我知道
  我是想知道为什么OFS没起作用
  奇怪的是我改变其中一个字段的值确能显示分隔符
  echo a b c d |awk ‘{OFS = ":";$2="3";print $0}‘
  a:3:c:d
  原来如此,谢谢
  原来如此,是什么原因啊?
  echo a b c d |awk ‘{OFS = ":";print $0}‘
  错误就在这里,$0是打印这条记录,OFS对它不起作用
  echo a b c d|awk ‘{OFS=":";print $1,$2,$3,$4}‘ 这样就对了
  下面引用由twlogin在 2002/09/28 01:50pm 发表的内容:
  奇怪的是我改变其中一个字段的值确能显示分隔符
  echo a b c d |awk ‘{OFS = ":";$2="3";print $0}‘
  ...
  那改变其中一个字段的值
  如
  echo a b c d |awk ‘{OFS=":";$2="b";print $0}‘
  结果又对了,why?
  是不是改变其中一个字段的值后,每个字段的会自动加上OFS
  只能说awk对于OFS的改变后,中间没有提供他任何加工输出数据的机会,那OFS的改变也失效了.
  awk也是个常人写得程序.总有不周之处啊.
  在《sed和awk编程篇》中有这样一句:
  如果给字段变量赋一个新值,那么awk会自动地使用内部变量OFS重新生成$0
  该书中讲解了 $0 什么被重新生成的例子

注意观察:echo "a:b:c" | awk ‘BEGIN{FS=":"}{OFS="#";$1=$1;print $0}‘这样也是可以的。

时间: 2024-12-08 00:22:05

AWK中的OFS的问题的相关文章

linux awk 中 RS,ORS,FS,OFS 区别与联系【转】

linux awk 中 RS,ORS,FS,OFS 区别与联系 http://blog.csdn.net/jesseen/article/details/7992929

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&quo

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中可以使用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            

在awk中通过system调用sql语句来说明引号的使用

一个实际应用例子: 在awk中,通过system调用连接数据库并作select操作,select语句中where条件来自于一个文件(file)的第一个域($1). $ cat file ... 1001 1002 1003 1004 ... 1. 用awk实现: awk '{system("mysql -u root -proot mydatabase -Bse \"select id,name from tables where id=""\047"$1

awk中split函数的用法

The awk function split(s,a,sep) splits a string s into an awk array a using the delimiter sep. time=12:34:56 echo $time | awk '{split($0,a,":" ); print a[1]}' 12   echo $time | awk '{split($0,a,":" ); print a[3]}' 34   echo $time | awk

AWK中for循环调用数组解释

以前对于awk中的for循环调用数组一直不是很清晰,通过这个例子你将会对这种方法非常明白. #!/bin/sh echo"" | awk ' BEGIN { a[1]="123" a[2]="456" a[3]="789" } END{ for(i in a) { print i,a[i] } }' 结果:

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

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

awk中NR和FNR的区别

NR  The total number of input records seen so far. FNR The input record number in the current input file. 简单翻译: NR  表示读到的文件行数 FNR 表示读到的当前文件行数 awk中NR和FNR的区别