フィールドとフィールドの値を含むcsvファイルを読み取り、入力からjson文字列を生成するbashスクリプトを作成しています。
簡単にするために、上記のスクリプトをシミュレートする2つのパラメータを受け入れるbashスクリプトがあります。
#!/bin/bash
fieldValue1=$1
fieldValue2=$2
jsonString='{"field1":"'$fieldValue1'", "field2":"'$fieldValue2'"}'
echo $jsonString
2つのパラメータを使用して上記のスクリプトを呼び出すと、次の出力が正しく表示されます。
./test.sh "abc" "def"
{"field1":"abc", "field2":"def"}
今やりたいことは、最初のパラメータに変数を割り当てて印刷してから、2番目のパラメータで最初のパラメータの変数を再利用できるようにすることです。
たとえば、次のパラメータを使用してスクリプトを呼び出すと(構文は柔軟です)。
./test.sh "VAR=abc;echo $VAR" "$VAR"
その後、出力は次のようになります。
{"field1":"abc", "field2":"abc"}
これを実際に使用する方法は、たとえば、大規模な入力ファイルの実際のスクリプトの場合、日付を一度だけ維持するだけです。
startDate1,field2,startDate2
var startDate=1/1/2020;echo $startDate,someValue,$startDate
2/1/2020,someOtherValue,$startDate
上記の結果を得るための最良の方法を知っている人はいますか?
ベストアンサー1
なぜダメなのvar=abc; ./test.sh "$var" "$var"
?
または、1つの引数を使用してスクリプトを呼び出すと、スクリプトは欠落している値を処理します。
#!/bin/bash
fieldValue1=$1
fieldValue2=${2:-$1}
...
その後:./test.sh foo
出力{"field1"="foo", "field2"="foo"}
これはJSONではありません。コロンの使用は次のようにはなりません。{"field1":"foo", "field2":"foo"}
また、jsonString変数を割り当てるときに変数の引用を解除します。これを行う
jsonString='{"field1":"'"$fieldValue1"'", "field2":"'"$fieldValue2"'"}'
# ......................^............^...............^............^
# or
jsonString="{'field1':'$fieldValue1', 'field2':'$fieldValue2'}"
# or
printf -v jsonString '{"field1":"%s","field2":"%s"}' "$fieldValue1" "$fieldValue2"
また、引用符文字を含む値を使用しないでください。
printf -v jsonString '{"field1":"%s","field2":"%s"}' \
"${fieldValue1//\"/\\\"}" \
"${fieldValue2//\"/\\\"}"
それから
$ ./test.sh 'he said "foo"'
{"field1":"he said \"foo\"","field2":"he said \"foo\""}
更新された要件に基づいています。変数の割り当て〜しなければならない別のステップです。君はまだ足りない$(...)
コマンドの置き換え通事論
まずスクリプトを更新します。
#!/bin/bash
pairs=()
for ((i=1; i<=$#; i++)); do
value=${!i}
pairs+=( "$(printf '"%s":"%s"' "field$i" "${value//\"/\\\"}")" )
done
IFS=,
echo "{${pairs[*]}}"
それからこう呼んでください。
startDate=1/1/2020
bash test.sh "$startDate" someOtherValue "$startDate" "$(date -u -d "$startDate 1 hour" "+%FT%TZ")" "anotherValue"
次の出力を取得します。
{"field1":"1/1/2020","field2":"someOtherValue","field3":"1/1/2020","field4":"2020-01-01T01:00:00Z","field5":"anotherValue"}