免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: play9091

[文本处理] 特別行提取 [复制链接]

论坛徽章:
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
发表于 2014-07-21 11:24 |显示全部楼层
回复 7# play9091


这个不能猜,要看教程:
http://bbs.chinaunix.net/thread-452942-1-1.html

论坛徽章:
0
发表于 2014-07-21 11:33 |显示全部楼层
回复 5# Herowinter


    求教,因為我要檢查上千個文件,但用 sed '$!d' 它只能顯示出最後一行,不能把每個文件的都顯示出來,請問有什麼解決方案?

论坛徽章:
766
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
发表于 2014-07-21 11:38 |显示全部楼层
本帖最后由 Herowinter 于 2014-07-21 11:40 编辑

回复 12# play9091
写个循环吧,大概框架这样的:
  1. for file in `ls xxxx`
  2. do
  3.     sed -n '/CXC4020065/{n;n;p;q}' file
  4. done
复制代码

论坛徽章:
0
发表于 2014-07-21 11:49 |显示全部楼层
本帖最后由 磨即 于 2014-07-21 11:50 编辑

学习


   

论坛徽章:
6
处女座
日期:2014-04-02 16:07:17酉鸡
日期:2014-04-14 10:09:22子鼠
日期:2014-04-17 11:57:30辰龙
日期:2014-09-01 17:14:08戌狗
日期:2014-10-28 12:25:54未羊
日期:2014-11-14 11:31:58
发表于 2014-07-21 11:51 |显示全部楼层
  1. awk '/CXC4020065/{getline;getline;print $0}' o
复制代码

论坛徽章:
0
发表于 2014-07-21 11:59 |显示全部楼层
回复 13# Herowinter


    sed 不會把 檔名放在前面,看來沒有比較簡便的方式了……好吧!謝謝您的指教!

论坛徽章:
0
发表于 2014-07-21 12:01 |显示全部楼层
回复 15# rulebook


    這個方式是可以把所有檔案的內容都正確的取出來,但是 awk 不會在結果裡面加上檔案名,看來只有 grep 有辦法……

论坛徽章:
1
双鱼座
日期:2014-08-25 19:13:11
发表于 2014-07-21 12:11 |显示全部楼层
awk '/CXC4020065/{getline;getline;print}' urfile

论坛徽章:
766
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
发表于 2014-07-21 13:05 |显示全部楼层
本帖最后由 Herowinter 于 2014-07-21 13:08 编辑

回复 16# play9091
原来你要加文件名,那这样吧。
  1. for file in `ls i[12]`;
  2. do
  3.     grep -H 'CXC4020065' -A 2 $file|sed '$!d'
  4. done

  5. i1-    Stop Date             : 2014-08-06
  6. i2-    Stop Date             : 2014-08-06
复制代码
或者
  1. for file in `ls xxoo`
  2. do
  3.     awk '/CXC4020065/{getline;getline;print FILENAME": "$0}'  $file
  4. done
复制代码

论坛徽章:
0
发表于 2014-07-21 13:39 |显示全部楼层
回复 19# Herowinter


    awk '/CXC4020065/{getline;getline;print FILENAME": "$0}'  *.log

這就是我想要的功能了,感謝 @Herowinter
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP