10

我有一个简单的脚本来检查网页是否包含指定的字符串。看起来像:

#!/bin/bash
res=`curl -s "http://www.google.com" | grep "foo bar foo bar" | wc -l`
if [[ $res == "0" ]]; then
    echo "OK"
else
    echo "Wrong"
fi

如您所见,我希望得到“OK”,但得到了“Wrong”。

它出什么问题了?

如果我使用 if [ $res == "0" ],它会起作用。如果我只使用 res="0" 而不是 res= curl...,它也可以获得所需的结果。

为什么会有这些差异?

4

2 回答 2

22

您可以看到res包含的内容:echo "Wrong: res=>$res<"

如果您想查看某些文本是否包含其他文本,则不必查看 grep 输出的长度:您应该查看 grep 的返回码:

string="foo bar foo bar"
if curl -s "http://www.google.com" | grep -q "$string"; then
    echo "'$string' found"
else
    echo "'$string' not found"
fi

甚至没有 grep:

text=$(curl -s "$url")
string="foo bar foo bar"
if [[ $text == *"$string"* ]]; then
    echo "'$string' found"
else
    echo "'$string' not found in text:"
    echo "$text"
fi
于 2012-09-16T10:17:48.283 回答
0

我在glenn jackman的帮助中找到了答案。

我在这个问题中得到以下几点:

  • wc -l的输出包含空格。
  • echo "$var"使用而不是调试echo $var
  • [[保留 var 中所有字符的字面值。
  • [在执行之前将 var 扩展为它们的值,这是因为 [ 实际上是testcmd,所以它遵循Shell Expansions规则。
于 2012-09-19T03:39:50.950 回答