shell脚本的awk错误

时间:2013-05-08 17:18:34

标签: shell awk grep

我的代码收到以下错误。它缺少什么?我的目标是在$ version

中打印13.0.5.8
 #!/bin/ksh

 file="abc_def_APP_13.0.5.8"
  if echo "$file" | grep -E "abc_def_APP"; then
        echo "Version found: $file"

    version1=(echo $file |  awk -F_ '{print $NF}' | cut -d. -f1-3)

    version2=(echo $file | awk -F_ '{print $NF}' | cut -d. -f4-)

    echo $version1

    echo $version2

        version=$version$version2

        echo $version
 else
       echo "Version not found"
  fi

请在下面找到错误:

 ./version.sh: line 7: syntax error near unexpected token `|'
./version.sh: line 7: ` version1=(echo $file |  awk -F_ '{print $NF}' | cut -d. -f1-3)'
./version.sh: line 9: syntax error near unexpected token `|'
./version.sh: line 9: ` version2=(echo $file | awk -F_ '{print $NF}' | cut -d. -f4-)'



./version.sh: line 18: syntax error near unexpected token `else'

3 个答案:

答案 0 :(得分:1)

问题是你的反引号丢失$你需要修复以下两行:

version1=$(echo $file |  awk -F_ '{print $NF}' | cut -d. -f1-3)

version2=$(echo $file | awk -F_ '{print $NF}' | cut -d. -f4-)

这将修复语法错误。由于$version尚未初始化,因此以下行没有多大意义:

version=$version$version2

你的意思是:

version="${version1}.${version2}"

请注意,您正在使用-E选项grep,但您没有使用任何扩展的正则表达式功能,实际上您正在进行固定的字符串搜索,因此-F是更合适。您可能还希望使用-q选项来禁止grep的输出。

就我个人而言:

file="abc_def_APP_13.0.5.8"

echo "$file" | awk '/abc_def_APP/{print "Version found: "$0;
                                  print $4,$5,$6;
                                  print $7;
                                  print $4,$5,$6,$7; 
                                  next}
                    {print "Version not found"}' FS='[_.]' OFS=.

如果您只想要变量version中的版本号,那么为什么不简单:

version=$(echo "$file" | grep -o '[0-9].*')

答案 1 :(得分:1)

根本不需要awk。只修剪最后一个下划线之前的每个字符,如下所示:

file="abc_def_APP_13.0.5.8"
version="${file##*_}"
echo "$version"

有关此技术的文档,请参阅http://mywiki.wooledge.org/BashFAQ/073,或参阅bash自己的文档中的“参数扩展”。

单独处理最后一段也很简单:

file="abc_def_APP_13.0.5.8"
version="${file##*_}"          # result: 13.0.5.8
version_end="${version##*.}"   # result: 8
version_start="${version%.*}"  # result: 13.0.5
echo "${version_start}/${version_end}" # result: 13.0.5/8

因为这在bash内部发生,而不执行任何外部命令(例如awk),所以执行它应该比给定的其他方法快得多。

答案 2 :(得分:0)

它可以在一个awk命令中完成,无需额外的cut命令。请考虑以下命令:

read version1 version2 < <(echo $file|awk -F "[_.]" '{
   printf("%s.%s.%s ", $4, $5, $6); printf("%s", $7);
   for (i=8; i<=NF; i++) printf(".%s", $i); print ""}')

echo "$version1 :: $version2"

输出

13.0.5 :: 8