Voglio stampare le righe dispari e pari dai file.
Ho trovato questo script di shell che utilizza echo.
#!/bin/bash
# Write a shell script that, given a file name as the argument will write
# the even numbered line to a file with name evenfile and odd numbered lines
# in a text file called oddfile.
# -------------------------------------------------------------------------
# Copyright (c) 2001 nixCraft project <http://cyberciti.biz/fb/>
# This script is licensed under GNU GPL version 2.0 or above
# -------------------------------------------------------------------------
# This script is part of nixCraft shell script collection (NSSC)
# Visit http://bash.cyberciti.biz/ for more information.
# -------------------------------------------------------------------------
file=$1
counter=0
eout="evenfile.$$" # even file name
oout="oddfile.$$" # odd file name
if [ $# -eq 0 ]
then
echo "$(basename $0) file"
exit 1
fi
if [ ! -f $file ]
then
echo "$file not a file"
exit 2
fi
while read line
do
# find out odd or even line number
isEvenNo=$( expr $counter % 2 )
if [ $isEvenNo -ne 0 ]
then
# even match
echo $line >> $eout
else
# odd match
echo $line >> $oout
fi
# increase counter by 1
(( counter ++ ))
done < $file
echo "Even file - $eout"
echo "Odd file - $oout"
Ma non c'è un modo per farlo in una riga?
Sì, usa awk, ho letto.
Linee pari:
awk 'NR % 2' filename
righe dispari:
awk 'NR % 2 == 1' filename
Ma non funziona per me. Entrambi producono lo stesso output, secondo diff. Rispetto al file originale, sono in effetti entrambi lunghi la metà e contengono entrambe le righe dispari. Sto facendo qualcosa di sbagliato?
NR % 2 == 0
, altrimenti è equivalente al secondo.