我有一个看起来像这样的脚本
#!/bin/bash
#
for i in `seq -w 22 35`
do
cd /folder/d"$i"
generate_XDS.INP d"$i"_001.img.bz2 #makes a text file "XDS.INP"
u=`grep UNIT_CELL_CONSTANTS /folder/d${i-1}/CORRECT.LP | tail -n 1` #get info from previous run
#u is supposed to be something like: UNIT_CELL_CONSTANTS= 79.08 79.08 37.02 90.000 90.000 90.000
sed -e "s:NAME_TEMPLATE_OF_DATA_FRAMES=./d${i}_001.img.bz2:NAME_TEMPLATE_OF_DATA_FRAMES=./d${i}_???.img.bz2:" -e 's:DATA_RANGE=:DATA_RANGE=1 100:' -e 's:SPOT_RANGE=:SPOT_RANGE=1 100:' -e 's:SPACE_GROUP_NUMBER=0:SPACE_GROUP_NUMBER=96:' -e "s:UNIT_CELL_CONSTANTS= 70 80 90 90 90 90:${u}:" XDS.INP > a #Change a few lines in input so that the job can run.
mv a XDS.INP
done
问题是" u = line"。我以前有这样的东西,没有u = line和sed行中的两个最后替换命令,并且它有效。现在你出现空了,sed命令没有成功结束。我怎样才能解决这个问题? 我知道这与{brace}扩展有关。但我不知道如何继续。
答案 0 :(得分:1)
我不知道这是否是实际问题,但${i-1}
不会像你想象的那样评估算术表达式。
使用$(( i - 1 ))
,它将在大多数shell中运行(如bash,dash等),并且是算术表达式的首选语法或使用$[ i - 1 ]
,它将在bash中起作用,但不能在其他一些贝壳中。此外,正如查尔斯达菲的评论所指出的那样,不鼓励采用后一种语法。