我正在尝试使用重置我的数据awk
。我有 54 列的数据,我想使用以下脚本更改其中六个列的值。
#!/bin/bash -x
# optimal parameters
set BI2=0.02841513
set DS2=0.37837487
set WS2=0.85392380
set D22=1.00048351
set D32=0.63893676
set DSMAX2=28.15795517
# change the calibration parameter
awk '{if($1==2) {
$6 = "${BI2}"
$7 = "${DS2}"
$8 = "${DSMAX2}"
$9 = "${WS2}"
$25 = "${D22}"
$26 = "${D32}"}
print $0;}' soil_params > tmp
mv -f tmp soil_params
我的数据如下:
999 0 123 65.183534 -147.655522 0.2 0.001 10 0.9 2 10.84 9.79 9.76 812.42 1546.28 1334.35 -999 -999 -999 18.579 68.139 26.914 548 0.1 0.3 0.192752 -0.8725 4 35.39 30.13 19.34 0.323 0.347 0.382 1160.4 1196.2 1208.9 2186.08 2253.52 2411.44 -9.8 0.582 0.489 0.443 0.396 0.4841 0.28 0.001 0.0005 383.7 0.1 0.1 0.1 1 16.733299 16.733299
2 1 124 65.183534 -147.639897 ${BI2} ${DS2} ${DSMAX2} ${WS2} 2 10.84 9.79 9.77 812.51 1544.96 1331.78 -999 -999 -999 18.579 68.277 26.915 676 0.1 ${D22} ${D32} -0.529166 4 35.45 30.19 19.37 0.323 0.347 0.382 1160.3 1196.3 1208.8 2185.87 2253.63 2411.11 -9.8 0.582 0.49 0.443 0.396 0.4851 0.28 0.001 0.0005 400.8 0.1 0.1 0.1 1 16.32 16.32
当我运行上面的脚本时,它没有更改分配的参数集中的值,而是对参数进行简单的更改,您可以
您能在这方面帮助我吗?
答案1
您面临的问题是您尝试在 awk 命令中使用由单引号 ( '...'
) 保护的 BASH 变量。在单引号内,bash 将不是展开变量(例如${BI2}
),因此 awk 将按字面意思查看$6 = "${BI2}"
,并将第 6 列的值设置为文字"${B12}"
。
幸运的是,您可以使用(又名)参数轻松地awk
从变量创建变量:shell
--assign
-v
awk \
-v BI2="${BI2}" \
-v DS2="${DS2}" \
-v DSMAX2="${DSMAX2}" \
-v WS2="${WS2}" \
-v D22="${D22}" \
-v D32="${D32}" \
'{if($1==2)
{
$6 = BI2; $7 = DS2; $8 = DSMAX2; $9 = WS2; $25 =D22; $26 =D32;
}
print $0;
}'
答案2
您将awk
脚本放在单引号中,通常建议这样做,因为它可以防止 shell 尝试替换 awk 定义的变量,例如$1
.不幸的是,这也意味着 shell 无法替换只有它知道的变量,例如$BI2
.如果您将调用awk
用双引号引起来:
awk "{if(\$1==2) {
\$6 = ${BI2}
\$7 = ${DS2}
\$8 = ${DSMAX2}
\$9 = ${WS2}
\$25 = ${D22}
\$26 = ${D32}}
print \$0;}" soil_params > tmp
然后外壳就会更换${BI2}
等等。但是,现在使用的变量awk
(例如$1
)必须编写为\$1
防止 shell 尝试为它们提供值。