아래에 키워드 word1
와 매트릭스가 포함된 파일이 있습니다.word2
word2
파일.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개 이상의 빈 줄로 구분된 단락에 있다고 가정합니다.