행 및 열 데이터를 동적으로 인쇄하고 동일한 파일에서 동일한 데이터를 업데이트하는 bash 스크립트를 작성하는 방법은 무엇입니까? [폐쇄]

행 및 열 데이터를 동적으로 인쇄하고 동일한 파일에서 동일한 데이터를 업데이트하는 bash 스크립트를 작성하는 방법은 무엇입니까? [폐쇄]

abc_hosts,pwd_host_id,pwd_host_id,호스트 이름,ddd_status,dddd_status,

start_hosts,,,,,,,,,,,,,,,,,,,1,o1,fhffhfh,1,1,fff,fdfd,172.33.33.33,172.30.30.12,172.30.30.11,oreere.dff ,43,443343,1111,43435,1099,43434443444,3232321312312 end_hosts,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, , ,, abc_hosts,pwd_host_id,pwd_host_id,호스트 이름,ddd_status,dddd_status,

start_hosts2,,,,,,,,,,,,,,,,,,,,1,o1,fhffhfh,1,1,fff,fdfd,172.33.33.33,172.30.30.12,172.30.30.11,oreere.dff ,43,443343,1111,43435,1099,43434443444,3232321312312 end_hosts2,,,,,,,,,,,,,,,,,,,,

답변1

awk스크립트를 사용하면 시작됩니다.

BEGIN { FS = "," }
$1 {
    if ($1 == "end_" tablename) {
        exit 0;
    } else if ($1 == "start_" tablename) {
        in_table = 1;
    } else if ($1 == tablename) {
        count = split($0, columns);
    }
    next;
}

in_table {
    for (i = 2; i <= NF; i++) {
        values[i] = values[i] "," $i;
    }
}

END {
    for (i = 2; i <= count; i++) {
        if (columns[i]) {
            print columns[i] " - " substr(values[i], 2);
        }
    }
}

다음과 같이 호출하세요.

awk -f config.awk -v tablename=interfaces_setup config.csv

관련 정보