특정 행렬을 grep하고 한 줄로 인쇄합니다.

특정 행렬을 grep하고 한 줄로 인쇄합니다.

아래에 키워드 word1와 매트릭스가 포함된 파일이 있습니다.word2word2파일.dat

  position1: [    0.0000000,    0.0000000,    0.0000000 ]
  word1:    0.0000000
  band:
  - # 1
    word2 :
    0.32015595   0.18484212   0.00000000
    0.00000000   0.36968424   0.00000000
    0.00000000   0.00000000   0.08286072 

  position2: [    0.5000000,    0.0000000,    0.0000000 ]
  word2:    0.0000000
  band:
  - # 1
    word2 :
    0.45015595   0.53484212   0.00000000
    0.00000000   0.36968424   0.00000000
    0.00000000   0.00000000   0.02476072 
    .
    .

이제 다음 형식으로 파일을 만들고 싶습니다.

position1 word1 word2
position2 word1 word2
.
.

하지만 여기서 단일 행 word2 행렬은 다음과 같습니다.

0.0000000 0.0000000 0.0000000  0.0000000    0.32015595   0.18484212 0.00000000 0.00000000   0.36968424   0.00000000 0.00000000   0.00000000 0.08286072 

추천을 사용했어요

awk '/ position | word1 | word2/ {w=w "$2" } END {print w}

하지만 예상한 결과가 나오지 않습니다. 누구든지 나를 도울 수 있습니까? 감사해요

답변1

$ awk -F': ' '/position[0-9]+:|word[0-9]+:/ {w=w" "$2 };
              /^[0-9. ]+$/ { w=w" "$0 };
              /^[[:blank:]]*$/ || eof {if (w) {gsub(/,/,"",w);print w;w=""}}' muthu.txt 
 [    0.0000000    0.0000000    0.0000000 ]    0.0000000     0.32015595   0.18484212   0.00000000     0.00000000   0.36968424   0.00000000     0.00000000   0.00000000   0.08286072 
 [    0.5000000    0.0000000    0.0000000 ]    0.0000000     0.45015595   0.53484212   0.00000000     0.00000000   0.36968424   0.00000000     0.00000000   0.00000000   0.02476072 

또는 (IMO) 약간 더 나은 형식을 사용하십시오.

$ awk -F': ' '/position[0-9]+:/ {p=$2 };

              /word[0-9]+:/ {w=$2};

              /^[0-9. ]+$/ {
                  if (!w2) { w2="[" };
                  w2=w2" ["$0" ]"
              };

              /^[[:blank:]]*$/ || eof {
                  l=p" "w" "w2;
                  gsub(/  +/," ",l);
                  gsub(/,/,"",l);
                  if (l ~ /^[[:blank:]]*$/) {next};
                  print l" ]";
                  p=w=w2=""
              }' muthu.txt 
[ 0.0000000 0.0000000 0.0000000 ] 0.0000000 [ [ 0.32015595 0.18484212 0.00000000 ] [ 0.00000000 0.36968424 0.00000000 ] [ 0.00000000 0.00000000 0.08286072 ] ]
[ 0.5000000 0.0000000 0.0000000 ] 0.0000000 [ [ 0.45015595 0.53484212 0.00000000 ] [ 0.00000000 0.36968424 0.00000000 ] [ 0.00000000 0.00000000 0.02476072 ] ]

둘 다 입력이 1개 이상의 빈 줄로 구분된 단락에 있다고 가정합니다.

관련 정보