출력 파일 특정 위치에서 변수를 가져오고 다음과 같이 입력 파일 형식을 원합니다.
log1.txt format:
[v] Output Data
<Value>DIMM_A,4096,1600,Hynix,HMT351S6CFR8C-PB,0942E041,1206,01,Hynix,,</Value>
or log2.txt format:
[v] Output Data
<Value>DIMM_B,4096,1600,Hynix,HMT351S6CFR8C-PB,017E90AE,1205,01,Hynix,,</Value>
<Value>DIMM_A,4096,1600,Hynix,HMT351S6CFR8C-PB,012E908D,1205,01,Hynix,,</Value>
다음과 같이 출력 OUT.TXT 파일 형식을 얻으려고합니다.
if log1.txt format and then output file format:
SET DIMM1=DIMM_A,4096,1600,Hynix,HMT351S6CFR8C-PB,0942E041,1206,01,Hynix,,
if log2.txt format and then output file format:
SET DIMM2=DIMM_B,4096,1600,Hynix,HMT351S6CFR8C-PB,017E90AE,1205,01,Hynix,,
SET DIMM1=DIMM_A,4096,1600,Hynix,HMT351S6CFR8C-PB,012E908D,1205,01,Hynix,,
누구에게 도움을 줄 수 있습니까? 감사!
답변
주요 문제는 우리가 얼마나 많은 라인을 Value
가지고 있는지 모른다 는 것입니다. 따라서 솔루션은 약간 복잡합니다.
sed -n '/^<Value/{s/^<[^>]*>/=/;s/<[^>]*>$//;p}' log1.txt | sort | cat -n |\
sed 's/^\s\+\([0-9]*\)\s\+=/SET DIMM\1=/'
여기서 첫 번째 sed
는 값으로 줄을 잡고 <>
태그를 제거 합니다. 그런 다음 줄 sort
을 정렬 cat -n
하고 열거하고 마지막 sed
으로 줄 번호를로 이동합니다 DIMM-num-
.
함께 awk
그것에 아주 가까이 될 것 sed
솔루션 :
awk -F'>' '/^<Value/{gsub ("<.*", "", $2);print $2}' log1.txt | sort |\
awk '{print "SET DIMM"NR"="$0}'