URN Logo
UNIX Resources » Linux » China Linux Forum » Perl 编 程 » 3 » 急:solaris2.8下awk和gnu 下的awk执行结果不一样,为什么?
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
急:solaris2.8下awk和gnu 下的awk执行结果不一样,为什么?
Author: zhangpw    Posted: 2005-04-07 21:23    Length: 1,306 byte(s)
[Original] [Print] [Top]
急:solaris2.8下awk和gnu 下的awk执行结果不一样,为什么?
问题:awk如何将数据每两个空行做为分隔,然后处理分隔后的信息块。
数据文件如下:
$ more t.txt
* ALARM 111111111
abcde


CLR ALARM 222222222
3333333333


444444444
555555555


** ALARM666666666
777777777
888888888


ALARM999999999

脚本如下:
$ more cu2.sh
input=$1
awk 'BEGIN{RS=" ";FS=" ";OFS=" "}{$1=$1;print $0 }' $input|awk '/ALARM/'| grep -v '^CLR'

在solaris2.8或者2.5版本运行得到以下结果:
$ cu2.sh t.txt
* ALARM 111111111
** ALARM666666666
ALARM999999999
$

在gnu下的awk(其他的linux也是)如下:
$ cu2.sh t.txt
* ALARM 111111111 abcde
** ALARM666666666 777777777 888888888
ALARM999999999

q3283c@tools-test2 /cygdrive/c/temp/shell
$

请教各位大侠,怎么能改成gnu那样的输出结果那。两个程序都没有错误,但是sun的结果不对。
[Original] [Print] [Top]
« Previous thread
如何删除一个文件中的指定行?
Perl 编 程
3
Next thread »
有啥简单办法给日期排序么?
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 04:08:55, cost 0.087258100509644 ms.