Linux打印输出指定行

打印前 N 行内容

# head 打印前 6 行内容
head -6 file.txt
head -n 6 file.txt

# sed 打印前 6 行内容
sed -n '1,6p' file.txt

# awk 打印前 6 行内容
awk 'NR<6' file.txt

打印指定行内容

# sed 打印第 6 行内容
sed -n '6p' file.txt

# awk 打印第 6 行内容
awk 'NR==6' file.txt

# tail 配合 head,打印指定行内容
tail -n +6 file.txt | head -1

 打印指定范围行内容

# sed 打印 6~10 行内容
sed -n '6,10p' file.txt

# awk 打印 6~10 行内容
awk 'NR>4 && NR<11' file.txt

# tail 配合 head,打印 6~10 行内容
tail -n +6 file.txt | head -6

打印跨行内容

# sed 打印第 3 行 和 6~7 行内容
sed -n '3p;6,7p' file.txt

# awk 打印第 3 行 和 6~7 行内容
awk 'NR==3 || (NR>4 && NR<8)' file.txt

 打印奇偶行内容

# 打印奇数行内容
# NR 表示行号
awk 'NR%2!=0' file.txt
awk 'NR%2' file.txt

# i 为变量,未定义变量初始值为 0,对于字符运算,未定义变量初值为空字符串
# 读取第 1 行记录,进行模式匹配:i=!0(!表示取反)。! 右边是个布尔值,0 为假,非 0 为真,!0 就是真,因此 i=1,条件为真打印第一条记录。
# 读取第 2 行记录,进行模式匹配:i=!1(因为上次 i 的值由 0 变成了 1),条件为假不打印。
# 读取第 3 行记录,因为上次条件为假,i 恢复初值为 0,继续打印。以此类推...
# 上述运算并没有真正的判断记录,而是布尔值真假判断。
awk 'i=!i' file.txt

# m~np:m 表示起始行;~2 表示:步长
sed -n '1~2p' file.txt

# 先打印第 1 行,执行 n 命令读取当前行的下一行,放到模式空间,后面再没有打印模式空间行操作,所以只保存不打印,同等方式继续打印第 3 行。
sed -n '1,$p;n' file.txt
sed -n 'p;n' file.txt

 打印偶数行

# 打印偶数行内容
awk 'NR%2==0' file.txt
awk '!(NR%2)' file.txt
awk '!(i=!i)' file.txt
sed -n 'n;p' file.txt
sed -n '1~1p' file.txt
sed -n '1,$n;p' file.txt

 打印最后 N 行内容

# tail 打印后 6 行内容
tail -6 file.txt
tail -n 6 file.txt

打印最后一行内容

# tail 打印最后一行内容
tail -n 1 file.txt

# sed 打印最后一行内容
sed -n '$p' file.txt

# awk 打印最后一行内容
awk 'END {print}' file.txt

 打印匹配行内容

# 打印以 "1" 开头的行内容
sed -n '/^1/p' file.txt
grep "^1" file.txt

# 打印不以 "1" 开头的行内容
sed -n '/1/!p' file.txt
grep -v "^1" file.txt

# 从匹配 "02" 行到第 6 行内容
sed -n '/02/,6p' file.txt

# 打印匹配 "02" 行 到匹配 "06" 行内容
sed -n '/02/,/06/p' file.txt

 

posted @ 2020-12-14 14:59  01234567  阅读(9413)  评论(0编辑  收藏  举报