Differences between revisions 5 and 15 (spanning 10 versions)
Revision 5 as of 2007-09-21 01:53:10
Size: 1042
Editor: p54884242
Comment:
Revision 15 as of 2011-02-12 13:54:42
Size: 1319
Editor: i577AF319
Comment: added simpler head|tail alternative for multiple lines
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
[[Anchor(faq11)]] <<Anchor(faq11)>>
Line 4: Line 4:
Line 22: Line 23:
Another approach, using ["AWK"]: Another approach, using [[AWK]]:
Line 30: Line 31:
   x=3 y=4
Line 32: Line 34:
   awk 'NR>=$x{print} NR==$y{exit}' "$file" # Same    head -n $y "$file" | tail -n +$x # even simpler
awk "NR>=$x{print} NR==$y{exit}" "$file" # Same
Line 35: Line 38:
Using cat(1) (and grep(1) (and cut(1))): === Note ===
In most cases, you should sanitize your variable n to be sure, that it's not containing any of non-digits, before feeding it to sed or awk. You can do it with such simple code:
{{{
   # Bash
   n=${n//[!0-9]/}
Line 37: Line 44:
{{{
   cat -n file | grep '^ *<number of line>' | cut -f 2
   # POSIX
   n=$(printf "%s" "$n"|tr -cd '0-9')
Line 40: Line 47:
----
CategoryShell

How can I print the n'th line of a file?

The dirty (but not quick) way would be:

    sed -n ${n}p "$file"

but this reads the whole input file, even if you only wanted the third line.

This one avoids that problem:

    sed -n "$n{p;q;}" "$file"

At line $n the command "p" is run, printing it, with a "q" afterwards: quit the program.

Another way, more obvious to some, is to grab the last line from a listing of the first n lines:

   head -n $n $file | tail -n 1 

Another approach, using AWK:

   awk "NR==$n{print;exit}" file

If you want more than one line, it's pretty easy to adapt any of the previous methods:

   x=3 y=4
   sed -n "$x,${y}p;${y}q;" "$file"                # Print lines $x to $y; quit after $y.
   head -n $y "$file" | tail -n $(($y - $x + 1))   # Same
   head -n $y "$file" | tail -n +$x                # even simpler
   awk "NR>=$x{print} NR==$y{exit}" "$file"        # Same

Note

In most cases, you should sanitize your variable n to be sure, that it's not containing any of non-digits, before feeding it to sed or awk. You can do it with such simple code:

   # Bash
   n=${n//[!0-9]/}

   # POSIX
   n=$(printf "%s" "$n"|tr -cd '0-9')


CategoryShell

BashFAQ/011 (last edited 2020-05-07 08:35:17 by intranet)