shell 脚本在调试时,FOR循环代码出现错误。怎么办?
代码是NUTCH1.0的recrawl脚本已经指向bin/bash附上出错的代码行for((i=0;i<$depth;i++))以及前后echo"-----Generat...
代码是NUTCH 1.0的recrawl脚本已经指向bin/bash 附上出错的代码行
for((i=0;i<$depth;i++))
以及前后
echo "----- Generate, Fetch, Parse, Update (Step 2 of $steps) -----"
for((i=0;i<$depth;i++))
do
echo "--- Beginning crawl at depth `expr $i + 1` of $depth ---"
$NUTCH_HOME/bin/nutch generate crawl/crawldb crawl/segments $topN \
-adddays $adddays
if [ $? -ne 0 ]
then
echo "runbot: Stopping at depth $depth. No more URLs to fetch."
break
fi
segment=`ls -d crawl/segments/* | tail -1` 展开
for((i=0;i<$depth;i++))
以及前后
echo "----- Generate, Fetch, Parse, Update (Step 2 of $steps) -----"
for((i=0;i<$depth;i++))
do
echo "--- Beginning crawl at depth `expr $i + 1` of $depth ---"
$NUTCH_HOME/bin/nutch generate crawl/crawldb crawl/segments $topN \
-adddays $adddays
if [ $? -ne 0 ]
then
echo "runbot: Stopping at depth $depth. No more URLs to fetch."
break
fi
segment=`ls -d crawl/segments/* | tail -1` 展开
1个回答
展开全部
原因:
因为你所处理的文件换行符是dos格式的”\r\n” ;
可以使用cat -v 文件名 来查看换行符是否是,如果是上述的,则行结尾会是^m 需要转换成linux/unix格式的”\n”;
具体转换办法就是转换换行符 。
可以用sed命令处理一下文件,命令如下:
sed ‘s/\r//’ 原文件 >转换后文件 ;
sed 命令的参数中 ”代表决定引用参数,不允许参数中的值让shell解释,s代表替换 /后面跟的是被替换的内容,后面的//代表替换后的内容为空 ;
推荐使用EditPlus或者UltraEdit,使用这些文本编辑工具,在保存时,可以选择保存的文字编码类型,比如选择UNIX格式换行符;
我比较喜欢EditPlus的join lines功能,把多行的值变成一个逻辑行,便于写到shell脚本中作为循环的变量。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询