I'm trying to get specific columns of a csv file (that Header contains "SOF" in case). Is a large file and i need to copy this columns to another csv file using Shell.
I've tried something like this:
#!/bin/bash
awk ' {
i=1
j=1
while ( NR==1 )
if ( "$i" ~ /SOF/ )
then
array[j] = $i
$j += 1
fi
$i += 1
for ( k in array )
print array[k]
}' fil1.csv > result.csv
In this case i've tried to save the column numbers that contains "SOF" in the header in an array. After that copy the columns using this numbers.
for (item in array). Your are currently using a Basy syntax instead.contains,thenandfiare not keywords inawk. You probably need a regex and~forcontains; the rest just needs converting from shell-ish to Awk. Also,$iin Awk is very different from$iin shell.