Reputation: 5
I have one text file. The content:
game1
game2
game3
game4
/usr/local/games
/usr/local/games
/usr/local/games
/usr/local/games
10
20
30
40
the output I want is like:
game1 /usr/local/games 10
game2 /usr/local/games 20
game3 /usr/local/games 30
game4 /usr/local/games 40
Upvotes: 0
Views: 66
Reputation: 203209
awk '
BEGIN { numRows = 4 }
{
rowNr = (NR-1)%numRows+1
colNr = ++colCnt[rowNr]
numCols = (colCnt[rowNr] > numCols ? colCnt[rowNr] : numCols)
val[rowNr,colNr] = $0
}
END {
for (rowNr=1; rowNr<=numRows; rowNr++)
for (colNr=1; colNr<=numCols; colNr++)
printf "%s%s", val[rowNr,colNr], (colNr < numCols ? OFS : ORS)
}
' file
game1 /usr/local/games 10
game2 /usr/local/games 20
game3 /usr/local/games 30
game4 /usr/local/games 40
Upvotes: 0
Reputation: 85775
One solution using awk
:
$ awk '{i=(NR-1)%n;a[i]=a[i](a[i]?"\t"$0:$0)}END{for(j=0;j<n;j++)print a[j]}' n=4 file
game1 /usr/local/games 10
game2 /usr/local/games 20
game3 /usr/local/games 30
game4 /usr/local/games 40
You can change the value of n
to match the block size of the input.
Upvotes: 2