免费注册 查看新帖 |

Chinaunix

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

如何截取文本文件中的段落 [复制链接]

pecker_zhao 该用户已被删除
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-15 15:57 |只看该作者 |倒序浏览
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
2 [报告]
发表于 2009-07-15 15:57 |只看该作者

回复 #5 pecker_zhao 的帖子

匹配的是时间戳那个字符串的格式,匹配ORA-19809的部分在/ORA-19809/那里。
你测试一下看看是不是符合需求啊,总得测一下才知道对不对嘛…… - -

还有就是,那些"."不是省略的,就直接拿去用……

论坛徽章:
0
3 [报告]
发表于 2009-07-15 16:05 |只看该作者
我在另一个帖子给过你建议的啊。
如果就是按日期分段落,取有"ORA-19809"的,这个就是可以的:

  1. awk -v RS="... ... .. ..:..:.. ...." '/ORA-19809/{printf s""$0}{s=RT}' URFILE
复制代码

论坛徽章:
0
4 [报告]
发表于 2009-07-15 16:06 |只看该作者

  1. for i in `cat tt14_arr.sh`; do  awk -v var1=$i 'NR==var1{print}' tt14.sh; done
复制代码

论坛徽章:
0
5 [报告]
发表于 2009-07-15 16:10 |只看该作者
while read i;do sed -n $i'p' file1;done<file2
pecker_zhao 该用户已被删除
6 [报告]
发表于 2009-07-15 16:11 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-01-24 06:20:00
7 [报告]
发表于 2009-07-15 16:12 |只看该作者
这个也是个中间的处理过程吧,楼主到底要在alert文件里取出啥东西来啊

论坛徽章:
2
丑牛
日期:2014-06-11 13:55:04ChinaUnix元老
日期:2015-02-06 15:16:14
8 [报告]
发表于 2009-07-15 16:17 |只看该作者
我觉得4楼的可以考虑

[ 本帖最后由 山野村夫 于 2009-7-15 16:19 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
9 [报告]
发表于 2009-07-15 16:25 |只看该作者

回复 #1 pecker_zhao 的帖子

你把打印行号换成打印内容不就可以了么?

awk '/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)/{s1=$0}/ORA-19809/{print s1;while(getline){if(/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)/){print s2;break};s2=$0}}' tt14.sh > tt14_arr.sh

论坛徽章:
0
10 [报告]
发表于 2009-07-15 16:37 |只看该作者

回复 #9 ly5066113 的帖子

刚才我也是这样做的,但很奇怪,打印NR时可以,打行内容会出错
  1. [root@Mylinux tmp]# awk '/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)/{s=$0}/ORA-19809/{print s;while(getline) {if(/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)/){print v;break}v=$0}}' file1
  2. Fri Jul 12 09:46:07 2009                                                                                                      
  3. ORA-16038 signalled during: ALTER DATABASE OPEN...                                                                             
  4. Sat Jul 12 09:46:07 2009                                                                                                      

  5. Sat Jul 12 09:46:07 2009                                                                                                      
  6. ORA-16038 signalled during: ALTER DATABASE OPEN...                                                                             
  7. [root@Mylinux tmp]#
复制代码

[ 本帖最后由 ywlscpl 于 2009-7-15 16:39 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP