[英]Grep from file fails but grep with individual lines from the file works
[英]If grep fails delete the file
Heya伙计们,我有这个小脚本,我需要grep所有的文件,只留下包含关键字的文件,我坚持这一点,任何帮助指出我的愚蠢的错误是赞赏:)
#!/bin/bash
server=(server1...server24)
.
.
.
for ((n=0; n <= 24 ; n++))
do
if grep -q "KEYWORD" directory/${server[$n]}.html ; then
echo Empty
else
rm -f directory/${server[$n]}.html
fi
done
.
.
.
如果您让代码通过以下方式之一为您执行操作,则无需确保计数匹配:
servers=(foo bar baz)
for server in ${servers[@]}
do
if ! grep -qs "KEYWORD" directory/$server.html
then
rm ...
要么
servers=(foo bar baz)
for ((n = 0; n < ${#servers[@]}; n++))
do
if ! grep -qs "KEYWORD" directory/${servers[$n]}.html
then
rm ...
用!
反转条件,使其“如果文件不包含关键字,则删除它”。
使用grep
选项-q
来清除输出和-s
以禁止显示错误消息。
你可以使用-l
选项为grep
grep -l "KEYWORD" directory/server*html | while read -r FOUND
do
rm -f .....
do some other processing here.....
done
确保以下内容:
用空格分隔数组中的服务器名称:
server=(server1 server2 server3 ... server24)
有效索引从0
到23
(比数组元素的数量少一个)。
所以你的for循环应该是:
for ((n=0; n <= 23 ; n++))
或for ((n=0; n < 24 ; n++))
我建议你为每个文件做grep,然后测试退出状态$?
- 并修复你的大括号扩展。
所以...
for ((n=0; n <= 24 ; n++))
do
grep -q "KEYWORD" directory/server${n}.html
if [ $? -eq 0 ] then
echo "directory/server${n}.html - Has keyword"
else
rm -f directory/server${n}.html
fi
done
#!/usr/bin/env bash
server=(server{1..24})
for((n=0; n<24; n++))
do
if grep -q 'keyword' ${server[$n]}; then
echo Empty
else
rm -f ${server[$n]}
fi
done
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.