免费注册 查看新帖 |

Chinaunix

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

删除指定文件段 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-03-03 12:04 |只看该作者 |倒序浏览
我如果想查找指定字符之间的文件段,并且在这个文件段中如果包含某一字符串,则将此文件段删除。如何做呀???
比如
begin time 20040303
first zhang
second liu
end time
begin time 20040303
first wang
second zhu
end time

删除包含second liu 的所有begin time 到end time

论坛徽章:
0
2 [报告]
发表于 2004-03-03 14:48 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2004-03-03 16:39 |只看该作者

删除指定文件段

如果你的文件中有很多这样的begin---end的段,不确定那一段之间包含second liu 你可以参考
cat file | grep -n -E "(second|end|begin)" | grep -1 'second' | grep -v -E '(\-|
econd)' | cut -d: -f1  | sed -n '$!N;s/\n/,/p'
提取出所有包含scond 的段的起始和中止行号。
至于怎样再删除这些段。你再自己想办法吧。

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
4 [报告]
发表于 2004-03-03 17:51 |只看该作者

删除指定文件段

试试这个^_^
  1. sed '/^begin time/{:a;N;/\nend time/bb;ba;:b;/\nsecond liu/d}' file
复制代码

论坛徽章:
0
5 [报告]
发表于 2004-03-03 18:09 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2004-03-04 09:17 |只看该作者

删除指定文件段

楼上的只能删除匹配模式的最后一行呀!
我根据nkoldbug的改了一下,ok了!!^_^
set file=$1
if ( -s 'log' ) then
        rm -rf log log1
endif
set first=1
foreach i (`sed -n '/^second liu/=' $file`)
set end = `expr $i - 3`
if ( $i - 2 != $first) then
        sed -n "$first,${end}p" $file >> log
endif
set first = `expr $i  + 2`
end
sed -n "$first,$$p" $file >> log

论坛徽章:
0
7 [报告]
发表于 2004-03-04 11:37 |只看该作者

删除指定文件段

[quote]原帖由 "r2007"]sed '/^begin time/{:a;N;/\nend time/bb;ba;:b;/\nsecond liu/d}' file[/quote 发表:


老兄请讲讲 :a, bb, ba, :b是什么意思?

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
8 [报告]
发表于 2004-03-04 12:00 |只看该作者

删除指定文件段

:a,:b类似basic语言中的标号。
bb,ba即goto 标号b,goto标号a。
我的表达不知是否清楚?

论坛徽章:
0
9 [报告]
发表于 2004-03-04 12:48 |只看该作者

删除指定文件段

可我对你的逻辑还是没搞清楚。你的代码太厉害了。
如果不嫌麻烦的话可否详细解释一下这条语句执行的过程?
另外我好像见过sed中用:a;ta。这个ta是什么意思?

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
10 [报告]
发表于 2004-03-04 13:27 |只看该作者

删除指定文件段

我的表达不太好,我将那一句写成一个脚本,并加了一些注释,希望对理解有所帮助。欢迎询问^_^
  1. /^begin time/ {
  2. :label1                 #set a label named label1
  3. N                       #read next line and append to pattern space
  4. /\nend time/b label2    #search for \nend time, if find then goto label2
  5. b label1                #otherwise goto label1, read next line and append
  6. :label2                 #set a label named label2
  7. /\nsecond liu/d         #if reach the end time string, then go here
  8.                         #and search \nsecond liu in the pattern space
  9.                         #if find, then delete it.
  10. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP