我有一个简单的脚本来检查网页是否包含指定的字符串。它看起来像:
#!/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”,但却得到了“错误”。
它出了什么问题?
如果我使用if [$ res ==“0”],它会起作用。如果我只使用res =“0”而不是res = curl...
,它也可以获得所需的结果。
为什么会出现这些差异?
答案 0 :(得分:18)
您可以看到res
包含的内容:echo "Wrong: res=>$res<"
如果你想看一些文本是否包含其他文本,你不必查看grep输出的 length :你应该看一下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
答案 1 :(得分:1)
我在glenn jackman的帮助中找到了答案。
我在这个问题中得到以下几点:
wc -l
的输出包含空格。echo "$var"
而非echo $var
[[
保留var中所有字符的字面值。[
在执行之前将var扩展为其值,因为[实际上是test
cmd,因此遵循Shell Expansions规则。