출력 파일에서 환경 변수에 액세스하는 방법


0

출력 파일 특정 위치에서 변수를 가져오고 다음과 같이 입력 파일 형식을 원합니다.

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,,

누구에게 도움을 줄 수 있습니까? 감사!

답변:


0

주요 문제는 우리가 얼마나 많은 라인을 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}'

명령 행을 시도했지만 결과 출력이 없습니다.
Sam

파일이 예와 같이 정확한 형식입니까? ^전에 제거해보십시오 <Value.
러시
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.