免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7364 | 回复: 15
打印 上一主题 下一主题

刚开始学sed,求助高手一个问题(sed分组命令) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-01 10:06 |只看该作者 |倒序浏览
[root@PANTA-Mtools study]# cat lists
CustomerSet.CUSTOMER_PAIR_UNUSED=2
CustomerSet.LOGOUT_SET_RADIO_DEFAULT=0
CustomerSet.LOGOUT_SET_TIME_DEFAULT=60

CustomerSet.CHART_DEFAULT_TYPE=USD/JPY#1#100_Customer
--------------------------------------------------------------
[root@PANTA-Mtools study]# sed -e '1,/^$/{/^$/d}' lists
CustomerSet.CUSTOMER_PAIR_UNUSED=2
CustomerSet.LOGOUT_SET_RADIO_DEFAULT=0
CustomerSet.LOGOUT_SET_TIME_DEFAULT=60
CustomerSet.CHART_DEFAULT_TYPE=USD/JPY#1#100_Customer

sed -e '1,/^$/{/^$/d}' lists 本意是取出文件第1行到空行之间的所有行,例如结果为A,
然后是分组命令{/^$/d},我对其的理解是在结果A的基础上再去掉空行,不知道这样理解的对不对。
要是按我的理解,
A为
CustomerSet.CUSTOMER_PAIR_UNUSED=2
CustomerSet.LOGOUT_SET_RADIO_DEFAULT=0
CustomerSet.LOGOUT_SET_TIME_DEFAULT=60
空行xxxxxxxxxxxxxxxxx

执行分组命令{/^$/d}后,结果应用
CustomerSet.CUSTOMER_PAIR_UNUSED=2
CustomerSet.LOGOUT_SET_RADIO_DEFAULT=0
CustomerSet.LOGOUT_SET_TIME_DEFAULT=60


可为什么实际结果为下面这个呢? 最后一行不是不在匹配模式中吗?为什么没有去掉?请高手解惑!
CustomerSet.CUSTOMER_PAIR_UNUSED=2
CustomerSet.LOGOUT_SET_RADIO_DEFAULT=0
CustomerSet.LOGOUT_SET_TIME_DEFAULT=60
CustomerSet.CHART_DEFAULT_TYPE=USD/JPY#1#100_Customer

论坛徽章:
0
2 [报告]
发表于 2011-12-01 10:59 |只看该作者
  自个顶一个

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
3 [报告]
发表于 2011-12-01 11:03 |只看该作者
sed -nr '1,/^[ \t]*$/p'

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
4 [报告]
发表于 2011-12-01 11:19 |只看该作者
按照你的思路:
  1. sed -n '1,/^$/{/^$/d;p}' urfile
复制代码

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
5 [报告]
发表于 2011-12-01 11:28 |只看该作者
  1. awk -v RS= '{print $0;exit}' urfile
复制代码

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
6 [报告]
发表于 2011-12-01 11:32 |只看该作者
sed '/^$/Q' urfile

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
7 [报告]
发表于 2011-12-01 11:33 |只看该作者
sed有个缺省动作p,楼主你忽视了

论坛徽章:
0
8 [报告]
发表于 2011-12-01 11:47 |只看该作者
回复 3# cjaizss


谢谢,不过这里讨论的是 分组命令 的实现过程,而不是要单纯的去掉空行

^[ \t]*$  学习了,[ \t]*会匹配的更严谨一些

论坛徽章:
0
9 [报告]
发表于 2011-12-01 11:53 |只看该作者
回复 4# Shell_HAT


斑主确实厉害
sed -n  '1,/^$/{/^$/d;p}'  urfile 完美解决了问题,不过{}中分组命令的实现难道都必须跟上p命令才可以吗

例如: sed  '1,/^$/d'  urfile  这个命令没有{}分组命令,就可以直接实现,而不用p命令

能解释下为什么吗

论坛徽章:
0
10 [报告]
发表于 2011-12-01 11:56 |只看该作者
回复 7# waker


你说的很对,确实缺少p命令,
sed -n '1,/^$/{/^$/d;p}' urfile  这样就可以实现了
按你说的缺省命令p,是分组命令中的缺省命令吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP