用于在多个每行字符数大于文件中搜索匹配串的脚本示例

王朝other·作者佚名  2006-11-23
宽屏版  字体: |||超大  

通常,我们可以用grep命令来搜索一个或多个文件中所包含的特定匹配字符串,比如:

# grep inittab /etc/*

/etc/init:

/etc/init:INIT:

/etc/init:

/etc/init:

/etc/inittab:: @(#)49 1.28.2.9 src/bos/etc/inittab/inittab, cmdoper, bos520 8/23/00 19:50:13

/etc/inittab:: bos520 src/bos/etc/inittab/inittab 1.28.2.9

/etc/inittab.bak:: @(#)49 1.28.2.9 src/bos/etc/inittab/inittab, cmdoper, bos520 8/23/00 19:50:13

/etc/inittab.bak:: bos520 src/bos/etc/inittab/inittab 1.28.2.9

/etc/rc.powerfail:# of /etc/inittab. The default command is:

但是,AIX操作系统上的grep命令有一行最多2048个字符的限制。如果要搜索的文件中包含了2048以上字符数的行,就会出现以下报错:

0652-226 Maximum line length of 2048 exceeded

为此,我们提供一种使用awk工具来搜索文件中的匹配串的方法,并提供一个示例脚本。

#!/bin/ksh

# Usage: awkgrep.sh PATTERN FILENAME

# For example, to find all files contain "inittab" under /etc, use:

# awkgrep.sh inittab /etc/*

#读取要匹配的串

pattern=$1

#生成包含awk子命令的临时文件

echo "/$pattern/ "'{print $0}' > /tmp/awkgrep$$

shift

#调用临时命令文件,搜索所有的目标文件

for fname in $*

do

if [ -f $fname ]

then

result=`awk -f /tmp/awkgrep$$ $fname`

if [ -n "$result" ]

then

echo $fname:

echo $result

echo

fi

fi

done

#删除临时文件

rm -f /tmp/awkgrep$$

此示例脚本不受每行2048字符的限制。它的输出如下所示:

# ./awkgrep.sh inittab /etc/*

/etc/inittab:

: @(#)49 1.28.2.9 src/bos/etc/inittab/inittab, cmdoper, bos520 8/23/00 19:50:13

: bos520 src/bos/etc/inittab/inittab 1.28.2.9

/etc/inittab.bak:

: @(#)49 1.28.2.9 src/bos/etc/inittab/inittab, cmdoper, bos520 8/23/00 19:50:13

: bos520 src/bos/etc/inittab/inittab 1.28.2.9

/etc/rc.powerfail:

# of /etc/inittab. The default command is:

参考资料:

附加下载文件: awkgrep.sh

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有