Я хочу получить переменные из определенного местоположения выходного файла и формат входного файла, как показано ниже:

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

кто бы ты мог мне помочь? Спасибо!

1 ответ1

0

Основная проблема в том, что мы не знаем, сколько строк с Value у нас есть. Поэтому решение немного сложнее:

sed -n '/^<Value/{s/^<[^>]*>/=/;s/<[^>]*>$//;p}' log1.txt | sort | cat -n |\
sed 's/^\s\+\([0-9]*\)\s\+=/SET DIMM\1=/'

где первый sed grep строки с Value и удаляет теги <> . После того, как эта sort отсортирует строки, cat -n перечислит их, а последний sed переместит номер строки в DIMM-num- .

С awk это было бы довольно близко к sed решению:

awk -F'>' '/^<Value/{gsub ("<.*", "", $2);print $2}' log1.txt | sort |\
awk '{print "SET DIMM"NR"="$0}'

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .