기존 문자열의 색인을 늘리는 방법은 무엇입니까?

기존 문자열의 색인을 늘리는 방법은 무엇입니까?

다음과 같은 문자열 값이 있고 아래와 같이 문자열의 인덱스를 증가시키고 싶습니다.

{
      "name": "poc_param_model_001",
      "type": "DOUBLE",
      "role": "MEASURE",
      "seq": 1
}

이것이 내가 하고 싶은 일이다.

{
          "name": "poc_param_model_002",
          "type": "DOUBLE",
          "role": "MEASURE",
          "seq": 2
}



{
              "name": "poc_param_model_003",
              "type": "DOUBLE",
              "role": "MEASURE",
              "seq": 3
}

{
              "name": "poc_param_model_004",
              "type": "DOUBLE",
              "role": "MEASURE",
              "seq": 4
}



....

{
              "name": "poc_param_model_099",
              "type": "DOUBLE",
              "role": "MEASURE",
              "seq": 99
 }

이 시나리오를 구현하는 방법은 무엇입니까?

답변1

데이터가 data.txt에 저장되어 있다고 가정하면 다음을 사용할 수 있습니다.

while IFS= read -r line
do
 if grep -q "^ *\"seq\" *: *[^ ]\+ *\$" <<< "$line"; then
  prefix=$(sed -E "s/^( *\"seq\" *: *)[^ ]+ *\$/\1/" <<< "$line" )
  number=$(sed -E "s/^ *\"seq\" *: *([^ ]+) *\$/\1/" <<< "$line" )
  suffix=$(sed -E "s/^ *\"seq\" *: *[^ ]+( *)\$/\1/" <<< "$line" )
  echo "$prefix$((++number))$suffix"
 else
  echo "$line"
 fi
done < data.txt

스크립트는 모든 데이터를 읽고 "seq"를 찾아 그 뒤에 오는 숫자를 증가시킵니다.

관련 정보