![AWK가 독립형 스크립트를 종료합니다.](https://linux55.com/image/76312/AWK%EA%B0%80%20%EB%8F%85%EB%A6%BD%ED%98%95%20%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%8A%B8%EB%A5%BC%20%EC%A2%85%EB%A3%8C%ED%95%A9%EB%8B%88%EB%8B%A4..png)
이 작업을 시작했는데... csv 파일의 필드를 교환했지만 스크립트를 완료할 수 없습니다. 내가 하고 싶은 일은 필드 2를 7까지 연결하고 첫 번째 필드를 기준으로 그룹화하는 것입니다. 각 행은 필드 1, 8, 9를 준수해야 합니다.
나는 일한다
BEGIN{
FS=";"
OFS="";
x="\"\"";
}
{
for(i=2;i<=7;i++){ if($i!= x)
k=match(a[$1], $i);
if (k == 0)
{
a[$1]=a[$1]";"$i;
}
b[$1]=b[$1]"-"$8""FS""$9;
}
END {
for (g in a)
t=split(a[g], A, ";");
if (t == 2)
{
a[g]=a[g]";"x";"x";"x";"x";"x";";
}
if (t == 3)
{
a[g]=a[g]";"x";"x";"x";"x";";
}
if (t == 4)
{
a[g]=a[g]";"x";"x";"x";";
}
if (t == 5)
{
a[g]=a[g]";"x";"x";";
}
for (h in b)
q=split(b[h], B, "-");
for (z=1; z <= q; z++)
b[h]=B[z];
}
}
CSV 파일;
"1033reto";"V09B";"";"";"";"";"";"QVN";"V09B"
"1033reto";"V010";"";"";"";"";"";"QVN";"V010"
"1033reto";"V015";"";"";"";"";"";"QVN";"V015"
"1033reto";"V08C";"";"";"";"";"";"QVN";"V08C"
"1040reto";"V03D";"";"";"";"";"";"QVN";"V03D"
"1040reto";"V01C";"";"";"";"";"";"QVN";"V01C"
"1050reto";"V03D";"";"";"";"";"";"QVN";"V03D"
"1050reto";"V01F";"V07L";"";"";"";"";"QVN";"V01C"
.......
원하는 출력;
첫 번째 그룹은 처음 4개 행의 필드 2~7을 연결한 것입니다. 그런 다음 동일한 첫 번째 필드가 있는 모든 행에 대해 이를 반복합니다. 두 번째 그룹은 다음 두 줄에서 필드 2~7을 연결한 것입니다. 그런 다음 동일한 첫 번째 필드가 있는 모든 행에 대해 이를 반복합니다. 세 번째 그룹은 마지막 두 행의 필드 2~7을 연결한 것입니다. 그런 다음 동일한 첫 번째 필드가 있는 모든 행에 대해 이를 반복합니다.
"1033reto";"V09B";"V010";"V015";"V08C";"";"QVN";"V09B"
"1033reto";"V09B";"V010";"V015";"V08C";"";"QVN";"V010"
"1033reto";"V09B";"V010";"V015";"V08C";"";"QVN";"V015"
"1033reto";"V09B";"V010";"V015";"V08C";"";"QVN";"V08C"
"1040reto";"V03D";"V01C";"";"";"";"";"QVN";"V03D"
"1040reto";"V03D";"V01C";"";"";"";"";"QVN";"V01C"
"1050reto";"V03D";"V01F";"V07L";"";"";"";"QVN";"V03D"
"1050reto";"V03D";"V01F";"V07L";"";"";"";"QVN";"V01C"
.......
답변1
이것앗스크립트는 원하는 출력을 생성합니다.
awk '
BEGIN {
FS = OFS = SUBSEP = ";"
}
$1 != f {
for (i = 2; i < 8; i++) {
line = line ";" A[i]
A[i] = $i
}
if (NR > 1)
for (j in B)
print f line, j
line = ""
delete B
count = 0
f = $1
}
/^$/ {
print $0
next
}
{
for (i = 2; i < 8; i++)
if ($i !~ /""/)
A[i + count] = $i
else
break
count += (i-2)
B[$8, $9] = 1
}
END {
for (j in B) {
printf "%s;", f
for (i = 2; i < 8; i++)
printf "%s;", A[i]
print j
}
}' "CSV File"