使用awk和sed获取文件奇偶数行的方法总结
测试文件test.file
[root@localhost ~]# cat test.file
111111111111111
222222222222222
333333333333333
444444444444444
555555555555555
666666666666666
777777777777777
888888888888888
999999999999999
1010101010101010
1) 打印奇数行的方法
[root@localhost ~]# sed -n '1~2p' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# sed -n 'p;n' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# sed -n '1,$p;n' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# sed '2~2d' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# awk 'NR%2==1' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# awk 'NR%2' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999 [root@localhost ~]# awk 'i=!i' test.file
111111111111111
333333333333333
555555555555555
777777777777777
999999999999999
2) 打印偶数行的方法
[root@localhost ~]# sed -n '2~2p' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# sed -n 'n;p' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# sed -n '1,$n;p' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# sed '1~2d' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# awk 'NR%2==0' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# awk '!(NR%2)' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010 [root@localhost ~]# awk '!(i=!i)' test.file
222222222222222
444444444444444
666666666666666
888888888888888
1010101010101010
打印奇偶行的方法总结
sed -n '1~2p' test.file 打印奇数行
sed -n '2~2p' test.file 打印偶数行 sed -n 'p;n' test.file 打印奇数行
sed -n 'n;p' test.file 打印偶数行 sed -n '1,$p;n' test.file 打印奇数行
sed -n '1,$n;p' test.file 打印偶数行 sed '2~2d' test.file 打印奇数行
sed '1~2d' test.file 打印偶数行 awk 'NR%2==1' test.file 打印奇数行
awk 'NR%2==0' test.file 打印偶数行 awk 'NR%2' test.file 打印奇数行
awk '!(NR%2)' test.file 打印偶数行 awk 'i=!i' test.file 打印奇数行
awk '!(i=!i)' test.file 打印偶数行
其他相关正则取值说明
1) 打印行号和内容
[root@localhost ~]# awk '{print NR":"$0}' test.file
1:111111111111111
2:222222222222222
3:333333333333333
4:444444444444444
5:555555555555555
6:666666666666666
7:777777777777777
8:888888888888888
9:999999999999999
10:1010101010101010 2) 每行间加一个空行
[root@localhost ~]# awk '1; { print "" }' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 [root@localhost ~]# awk '1 { print } { print "" }' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 [root@localhost ~]# awk '{ print } { print "" }' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 [root@localhost ~]# awk 'BEGIN { ORS="\n\n" }; 1' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 3) 仅输出非空行,并每行间在加一个空行
# awk 'NF { print $0 "\n" }' test.file
NF表示当前行的字段数,$0表示当前行,最后再加一个换行 4) 双倍行距;没行间两个空行
默认输出后会换行的,输出\n,则会输出两个空白行
[root@localhost ~]# awk '1; { print "\n" }' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 [root@localhost ~]# awk '{ print; print "\n" }' test.file
111111111111111 222222222222222 333333333333333 444444444444444 555555555555555 666666666666666 777777777777777 888888888888888 999999999999999 1010101010101010 5) 显示当前行在所在文件中的行号
FNR,表示当前行在文件中的行号
[root@localhost ~]# awk '{ print FNR "\t" $0 }' test.file
1 111111111111111
2 222222222222222
3 333333333333333
4 444444444444444
5 555555555555555
6 666666666666666
7 777777777777777
8 888888888888888
9 999999999999999
10 1010101010101010 6) 显示当前行在本次处理过程中的行号
NR,表示当前行在本次处理过程中的行号
[root@localhost ~]# awk '{ print NR "\t" $0 }' test.file
1 111111111111111
2 222222222222222
3 333333333333333
4 444444444444444
5 555555555555555
6 666666666666666
7 777777777777777
8 888888888888888
9 999999999999999
10 1010101010101010 为啥有FNR和NR的差别呢?效果不都是一样么?
如果使用两个文件filname1.ext filname2.ext,则就会看到差别了。
原来:FNR,是每个文件中的,换了一个文件,会归零;而NR则每个文件会累加起来的 7) 使用简单样式来输出
下面表示"行号占用5位,不足补空格"
[root@localhost ~]# awk '{ printf("] : %s\n", NR, $0) }' test.file
] : 1
] : 2
] : 3
] : 4
] : 5
] : 6
] : 7
] : 8
] : 9
] : 10 8) 显示非空行
# awk 'NF { $0=++a " :" $0 }; { print }' test.file
NF前面说了,表示当前行的行号,此处用他作为条件,如果是空行,则NF为0,跳过;否则,用动态变量a存储非空行的数目 9) 计算行数:效果类似wc -l
END表示每行都处理完了后,在执行,此时NR就是最后一行的行号,也就是总的行数了。
#awk 'END { print NR }' test.file 10) 计算每一行的和
s用作每行和的累加,从1到NF(每行总的字段数),依次累加
# awk '{ s = 0; for (i = 1; i <= NF; i++) s = s+$i; print s }' test.file 11) 计算文件中所有字段的和
s用作总和的累加,每行都处理完成了,再输出s;注意和10对比,此处没有每行清零,所以累加了。没有设置的变量,默认为空,
但是会根据上下文数值计算情况自动变为0
# awk '{ for (i = 1; i <= NF; i++) s = s+$i }; END { print s }' test.file 12) 将每个字段用其绝对值代替
$i表示当前行中的字段,$0表示当前行,可以改变$i的值
# awk '{ for (i = 1; i <= NF; i++) if ($i < 0) $i = -$i; print }' test.file 13) 计算文件中总的字段和(例如计算单词数)
# awk '{ total = total + NF }; END { print total }' test.file 14) 计算匹配指定信息的总行数
# awk '/Linux/ { n++ }; END { print n+0 }' test.file 15) 找到文件中每行第一个字段中,最大的数,以及其所在的行
用max存储最大的数,maxline存储最大数所在的行,并在最后输出
# awk '$1 > max { max=$1; maxline=$0 }; END { print max, maxline }' test.file 16) 显示当前行的字段数,并输出当前行
# awk '{ print NF ":" $0 } ' test.file 17) 显示每行最后一个字段的内容
# awk '{ print $NF }' test.file #NF表示当前行的字段数,例如为3,则$NF,就是$3,也就是第三个字段了 18) 显示最后一行的最后一个字段
每行处理没有输出,尽在最后输出,field作为每行的最后一行的暂存变量
# awk '{ field = $NF }; END { print field }' test.file 19) 显示字段数小于4的行
# awk 'NF < 4' test.file 20) 显示每行的最后一个字段小于4的行
# awk '$NF < 4' test.file
shell脚本,实现奇数行等于偶数行
[root@localhost ~]# cat kevin.file
aa
11
bb
22
cc
33
dd
44 使用awk命令可以这样实现:
[root@localhost ~]# awk 'NR%2==0{print a"="$0}{a=$0}' kevin.file
aa=11
bb=22
cc=33
dd=44 使用shell脚本可以这样实现:
[root@localhost ~]# cat kevin.sh
#!/bin/bash
n=0
for i in $(cat /root/kevin.file)
do
n=$(($n+1))
[ $((n%2)) -eq 1 ] && echo -n $i=
[ $((n%2)) -eq 0 ] && echo $i
done [root@localhost ~]# sh kevin.sh
aa=11
bb=22
cc=33
dd=44
使用awk和sed获取文件奇偶数行的方法总结的更多相关文章
- (转)CSS3:nth-child()伪类选择器,奇偶数行自定义样式first-child
原文地址 Table表格奇偶数行定义样式: CSS3的强大,让人惊叹,人们在惊喜之余,又不得不为其艰难的道路感到可惜:好的标准只有得到行业浏览器的良好支持才算得上“标准”.CSS3标 准已提出数年,但 ...
- linux 下获取文件最后几行
在Linux下,获取文件倒数几行的命令是: tail -n 10 your_filename #获取倒数10行
- php获取文件后缀的9种方法
获取文件后缀的9种方法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 3 ...
- CSS3:nth-child()伪类选择器,Table表格奇偶数行定义样式
转自爱设计 原文链接http://www.dangshopex.com/jishufenxiang/WEBkaifajishu/8653.html CSS3的强大,让人惊叹,人们在惊喜之余,又不得不为 ...
- awk、sed处理文件的简单例子
awk.sed对处理日志文件和写shell脚本时非常有益.这个东西,如果不经常操作,真心过一段时间就忘差不多..要掌握熟练,就要多练习,这没什么可说的. awk '条件{命令}' filename 假 ...
- shell获取文件最后100行,开头100行,指定开始行和结束行的内容
文件最后100行:tail -n100 filePath: 文件开头100行:head -n100 filePath: 文件指定开始行和结束行的内容:sed '1,100p' filePath: 文件 ...
- php获取文件mime类型Fileinfo等方法
前几天写到使用wordpress xmlrpc api远程发布文章,如果本地服务器的文章库里某一篇待发表的wordpress文章包含图片文件时,就会使用到WordPress上传文件的API metaW ...
- PHP获取文件扩展名的多种方法
PHP获取文件扩展名的N种方法. 第1种方法: function get_extension($file) { substr(strrchr($file, '.'), 1): } 第2种方法: fun ...
- Java获取文件Content-Type的四种方法
HTTP Content-Type在线工具 有时候我们需要获取本地文件的Content-Type,已知 Jdk 自带了三种方式来获取文件类型. 另外还有第三方包 Magic 也提供了API.Magic ...
随机推荐
- php常用字符串方法
chop() 移除字符串右侧的空白字符或其他字符 ltrim() 移除字符串左侧的空白字符或其他字符 rtrim() 移除字符串右侧的空白字符或其他字符 tr ...
- spo0lsv病毒分析
1.样本概况 1.1 样本信息 病毒名称:spo0lsv.exe 所属家族:Worm MD5值:512301C535C88255C9A252FDF70B7A03 SHA1值:CA3A1070CFF31 ...
- Codeforces Round #485 (Div. 2) C. Three displays
Codeforces Round #485 (Div. 2) C. Three displays 题目连接: http://codeforces.com/contest/987/problem/C D ...
- vim快捷键速查
一.移动 h/j/k/l 左/下/上/右 W w 移动到下一个单词开头 E e 移动到下一个单词结尾 B b ...
- 可遇不可求的Question之MySql4.0前版本不支持union与批量SQL提交
批量SQL提交 参考 21.2.6. Connector/NET Connection String Options Reference . Allow Batch true When true, m ...
- U-Boot bootargs简析
Linux内核启动时需要一些配置信息,如根文件系统的类型.flash分区情况.串口终端的编号.内存的使用情况等等,而由于U-Boot和Linux Kernel的镜像是独立的两个文件,所以只能两者约定好 ...
- 12 week work
调用一个地图API <html> <head> <meta http-equiv="Content-Type" content="text/ ...
- Mac再建管理员帐户
在Mac上添加用户没有成功, 把原来的管理员的用户群组修改后, 账户类型成为普通用户. 百度如何重新添加管理员: Mac上修改用户名后,无法用管理员账号和密码登录. 按照超过方法下去, 出现问题: 1 ...
- Vipe-技术选型
1.AOP,IOC框架-Spring 选择Spring是最不需要考虑的.应该90%以上的JAVA项目都有用Spring. 2.ORM框架-Mybatis Mybatis入门比较简单,并且对SQL语法的 ...
- 背水一战 Windows 10 (118) - 后台任务: 后台下载任务(任务分组,并行或串行执行,组完成后通知)
[源码下载] 背水一战 Windows 10 (118) - 后台任务: 后台下载任务(任务分组,并行或串行执行,组完成后通知) 作者:webabcd 介绍背水一战 Windows 10 之 后台任务 ...