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

通常,我们可以用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=

Published At
Categories with 服务器类
Tagged with
comments powered by Disqus