【问题标题】:AWK array syntax error (unexpected newline or end of string)AWK 数组语法错误(意外的换行符或字符串结尾)
【发布时间】:2013-07-11 14:59:55
【问题描述】:

我一直在尝试运行以下 bash 脚本,但出现错误:

awk: cmd. line:1: -
awk: cmd. line:1:  ^ unexpected newline or end of string

我一直试图找出问题所在,但无济于事。我需要为一个项目紧急运行脚本,所以任何帮助将不胜感激!

输入文件(称为“输入”):

0    13    1495.015    1495.02d0    3.03607E-09    0.000000    0.00000E+00
0    14    1598.750    1598.57d0    1.90704E-09    0.000000    0.00000E+00
0    15    1701.372    1700.87d0    1.26357E-09    0.000000    0.00000E+00
0    16    1803.382    1802.22d0    9.11215E-10    0.000000    0.00000E+00
0    17    1906.131    1904.54d0    7.17855E-10    0.000000    0.00000E+00
0    18    2009.553    2007.55d0    5.88960E-10    0.000000    0.00000E+00
0    19    2113.543    2110.84d0    4.86193E-10    0.000000    0.00000E+00
0    20    2217.641    2214.16d0    4.09698E-10    0.000000    0.00000E+00
0    21    2321.638    2317.24d0    3.53609E-10    0.000000    0.00000E+00
0    22    2426.151    2420.84d0    3.12269E-10    0.000000    0.00000E+00
0    23    2530.983    2524.70d0    2.80847E-10    0.000000    0.00000E+00
0    24    2636.078    2629.18d0    2.52442E-10    0.000000    0.00000E+00

脚本开始:

largesep_obs=103.188

avg_n="`awk '{sum_n+=$2} END{avg=sum_n/NR; print(avg)}' input`"

avg_ref="`awk '{sum_ref+=$3} END{avg=sum_ref/NR; print(avg)}' input`"

avg_obs="`awk '{sum_obs+=$4} END{avg=sum_obs/NR; print(avg)}' input`"

num="`awk -v avg_n=$avg_n -v avg_obs=$avg_obs '{sum+=($4-avg_obs)*($2-avg_n); print(sum)}' input`"

den="`awk -v avg_n=$avg_n '{sum+=($2-avg_n)**2}' input`"

largesep_ref=$num/$den

r=1

nu_not=2000

b="( $r*$largesep_ref/$largesep_obs-1 )*( $r*$avg_ref/$avg_obs-1 )**-1"

den_of_a=`awk -v avg_obs=$avg_obs -v avg_ref=$avg_ref -v nu_not=$nu_not -v b="$b" '{sum+=(($4/nu_not)**b)} END{ans=sum/NR; print(ans)}' input`

a=($avg_obs - $r*$avg_ref)/$den_of_a

no_of_rows=12

awk -v nu_not=$nu_not -v r=$r -v a=$a -v b=$b -v no_of_rows=$no_of_rows '\"{
            for (x=1; x<=no_of_rows; x++) {
            array[x]=r*$3 + a*(($4/nu_not)**b)
        print("%s", vector[x])
        print("\n")
            }           
}'\" input

【问题讨论】:

  • 您能缩小问题的范围吗?您在脚本中运行 awk 7 次,哪些出现错误?
  • 我怀疑问题出在最后一个awk 命令中的\"。但我不知道你在那一个做什么。为什么它在输入的每一行都运行for 循环,但不使用输入中的任何内容?
  • 扔掉这个脚本,然后发布一些小的示例输入和预期的输出,并描述你想要做什么,并请求帮助编写一个脚本来做到这一点。

标签: bash syntax awk syntax-error


【解决方案1】:

你的脚本有很多问题,很难知道从哪里开始。

前 3 个awk 命令可以在一个脚本中完成:

avgs=(awk '{ sum_n += $2; sum_ref += $3; sum_obs +=$4; }
           END { print sum_n/NR; sum_ref/NR; sum_obs/NR }' input)
avg_n=${avgs[0]}
avg_ref=${avgs[1]}
avg_obs=${avgs[2]}

我不确定你在 numden 的作业中做了什么。您将输入文件提供给awk,但您只是在每一行上添加相同的内容,而不对输入做任何事情。在num 分配中,您打印每一行的运行总计,但稍后您使用$num,就好像它只包含一个数字一样; print(sum) 应该在 END 子句中吗?另一方面,den 分配中的awk 命令根本没有任何print 命令,因此那里没有分配任何内容。

b="( $r*$largesep_ref/$largesep_obs-1 )*( $r*$avg_ref/$avg_obs-1 )**-1"
a=($avg_obs - $r*$avg_ref)/$den_of_a

不执行计算,他们只是将整个公式作为字符串分配给变量。如果要计算,需要使用let((...))

让 b=( $r*$largesep_ref/$largesep_obs-1 )( $r$avg_ref/$avg_obs-1 )**-1 a=((($avg_obs - $r*$avg_ref)/$den_of_a))

最后一个awk 命令应该是:

awk -v nu_not=$nu_not -v r=$r -v a="$a" -v b="$b" -v no_of_rows=$no_of_rows '{
            for (x=1; x<=no_of_rows; x++) {
            array[x]=r*$3 + a*(($4/nu_not)**b)
        print("%s", vector[x])
        print("\n")
            }           
}' input

关于- 的错误消息来自未引用$a - 它将$a 中的- 视为单独的参数,并将其解释为要读取的输入文件(意思是标准输入) .但是b=$b 的扩展导致了语法错误。我也无法在您的脚本中看到 \" 的原因。

【讨论】:

    【解决方案2】:

    您的脚本可能会更好。尝试阅读Effective AWK Programming 并从头开始。

    问题是最后一个脚本,您可以通过一些更好的调试技术找到它。语法正确的版本是:

    awk '{for (x=1; x<=no_of_rows; x++) {
            array[x]=r*$3 + a*(($4/nu_not)**b)
            print vector[x]
            print "\n"
         }
     }' nu_not="$nu_not" r="$r" a="$a" b="$b" no_of_rows="$no_of_rows" input
    

    整个脚本应该写成单个awk 脚本。另外,print 不是awk 中的函数,它是一个语句。

    【讨论】:

    • 提名+1。为了解决他的大部分问题,我能得到什么吗?不过,我可能错过了一些事情。
    • 哈哈,你得到了 +1,但肯定还有一些我们都没有提到的问题,但我觉得这将是一种浪费。
    猜你喜欢
    • 1970-01-01
    • 2021-01-30
    • 1970-01-01
    • 2020-11-18
    • 1970-01-01
    • 2014-08-16
    • 2017-10-31
    • 2014-08-30
    • 1970-01-01
    相关资源
    最近更新 更多