免费注册 查看新帖 |

Chinaunix

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

怎样删除符合特定条件以后的行? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-02-07 09:54 |只看该作者 |倒序浏览
cat  a.txt
(纯益)        纯益       209214.74
(本部)        纯益        793562.26
(本部)        纯损        2894.71
(本部)        纯益        3231.56
(美圆)       纯益       456.78
(本部)        纯损        9404.51
(本部)        纯益        1446.04
(本部)        纯益        67692.45
(本部)        纯损        365.29
(本部)        纯损        5051.53


如何删除(美圆)开头的以下所有的行(包含(美圆)开头的行)?

论坛徽章:
0
2 [报告]
发表于 2006-02-07 09:59 |只看该作者
grep -v ^'(美圆)'

论坛徽章:
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
3 [报告]
发表于 2006-02-07 10:03 |只看该作者
sed '/(美圆)/{d;q}' file
请读置顶文章

论坛徽章:
0
4 [报告]
发表于 2006-02-07 10:04 |只看该作者
sed '/^(美圆)/Q' a.txt

论坛徽章:
0
5 [报告]
发表于 2006-02-07 10:10 |只看该作者
我看错题目了...

论坛徽章:
0
6 [报告]
发表于 2006-02-08 09:53 |只看该作者
sed '/^(美圆)/, $ d' filename

论坛徽章:
0
7 [报告]
发表于 2006-02-09 12:19 |只看该作者

问一个类似的问题

问一个类似的问题:如何删除符合特定条件第二次出现以后的行
例如
#more delA
outp
line1
line2
line3
outp
line4
line5
line6
outp
line7
line8
line9

要得到的结果如下:
outp
line1
line2
line3

同一个文件(如:delA)中两个outp之间的行数是固定的,不同的文件(如:delA和delB)则不一定.

[ 本帖最后由 ha_ 于 2006-2-9 12:36 编辑 ]

论坛徽章:
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
8 [报告]
发表于 2006-02-09 13:19 |只看该作者
2 ha_

sed '/^outp/{x;/^outp/Q;g}' file

用awk就更不用说了吧?

论坛徽章:
0
9 [报告]
发表于 2006-02-09 13:54 |只看该作者
just for fun

  1. ex -c "`grep -n outp data|head -2|tail -1|cut -d':' -f1`,\$d" -c 'x' data
复制代码

论坛徽章:
0
10 [报告]
发表于 2006-02-09 14:06 |只看该作者
#echo \'`iostat -xp 2 1| wc -l | sed 's/^ *//'`q\'
'19q'
#sed \'`iostat -xp 2 1| wc -l | sed 's/^ *//'`q\' io (io是一个文本文件)
Unrecognized command: '19q'

为什么第二行会把'19q' 解释成命令.

你好,小灰狼:
我的思路和你的一样,就是取得第二个符合特定条件的行的行号
  1. grep -n outp del | head -2 | tail -1 | cut -d':' -f1
复制代码

然后再sed 'nq' filename就可以了.我用iostat命令的输出行作统计取得行号更符合我的情况
因为iostat的前两行输出是标头,用grep比较晦涩.

  1. # iostat -xp 2 1
  2.                   extended device statistics
  3. device       r/s    w/s   kr/s   kw/s wait actv  svc_t  %w  %b
  4. sd0          0.2    0.9    2.3    6.5  0.0  0.0   21.1   0   1
  5. .........................
  6. .........................
复制代码

[ 本帖最后由 ha_ 于 2006-2-9 14:33 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP