免费注册 查看新帖 |

Chinaunix

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

使用shell / awk / sed 统计日志行数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-05-15 00:00 |只看该作者 |倒序浏览
日志内容
180.171.230.214 - - - [14/May/2011:20:28:10 +0800] "GET /promotion/gyp/20100602/maoyitong/index
180.171.230.215 - - - [14/May/2011:20:28:14 +0800] "GET /promotion/gyp/20100602/maoyitong/index
.....
.....
.....
110.75.196.130 - - - [14/May/2011:20:40:45 +0800] "GET / HTTP/1.1" 200 1
159.140.25.218 - - - [14/May/2011:20:28:50 +0800]  "http://xxx.com"
117.121.32.185 - - - [14/May/2011:20:28:50 +0800] "GET /homepage-market-conditio

我想统计从 14/May/2011:20:28:10 到 14/May/2011:20:28:50 之间的所有日志行数,

使用 sed -n '/14\/May\/2011:20:28:10/,/14\/May\/2011:20:28:50 +0800/p'  只能打印  159.140.25.218 - - - [14/May/2011:20:28:50 +0800]  "http://xxx.com" 这条,这条后的同样时间的就不打印了,

请问使用shell / sed / awk 应怎么写呢?

论坛徽章:
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
2 [报告]
发表于 2011-05-15 03:39 |只看该作者
  1. awk '/14\/May\/2011:20:28:10/,/14\/May\/2011:20:28:50 +0800/' urfile
复制代码

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
3 [报告]
发表于 2011-05-15 03:57 |只看该作者
回复 1# dmidecode


sed -n '/14\/May\/2011:20:28:10/,/14\/May\/2011:20:28:50 \+0800/p'

论坛徽章:
0
4 [报告]
发表于 2011-05-15 06:50 |只看该作者
+0800前面加和不加\有什么区别,在awk和sed中分别有什么不同?

论坛徽章:
0
5 [报告]
发表于 2011-05-15 10:20 |只看该作者
回复 4# Estwind


    没有转义符+号是有特别意义的。

论坛徽章:
0
6 [报告]
发表于 2011-05-15 10:34 |只看该作者
回复 3# yinyuemi

请问在前面为何不用加 +0800 ,在后面要加 +0800 这个呢,

我刚才试了一下,如果前面加 +0800 的话会任何东西都打印不出来!

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
7 [报告]
发表于 2011-05-15 11:33 |只看该作者
本帖最后由 yinyuemi 于 2011-05-15 11:40 编辑

回复 6# dmidecode


试试下面的吧,我前面的回复不对,另外sed里的+不需要转义,

因为不管是awk还是sed, /foo1/,/foo2/的匹配的是第一个foo1到第一个foo2(对这点,以前的理解还是不到位啊),这也就是为什么你开始的代码无法打印出最个那行;
  1. cat test
  2. abc
  3. 180.171.230.214 - - - [14/May/2011:20:28:10 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  4. 180.171.230.215 - - - [14/May/2011:20:28:14 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  5. .....
  6. .....
  7. .....
  8. 110.75.196.130 - - - [14/May/2011:20:40:45 +0800] "GET / HTTP/1.1" 200 1
  9. 159.140.25.218 - - - [14/May/2011:20:28:50 +0800]  "http://xxx.com"
  10. 117.121.32.185 - - - [14/May/2011:20:28:50 +0800] "GET /homepage-market-conditio
  11. seg


  12. awk '/14\/May\/2011:20:28:10 \+0800/{p=1}/14\/May\/2011:20:28:50 \+0800/{print;p=0}p' test
  13. 180.171.230.214 - - - [14/May/2011:20:28:10 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  14. 180.171.230.215 - - - [14/May/2011:20:28:14 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  15. .....
  16. .....
  17. .....
  18. 110.75.196.130 - - - [14/May/2011:20:40:45 +0800] "GET / HTTP/1.1" 200 1
  19. 159.140.25.218 - - - [14/May/2011:20:28:50 +0800]  "http://xxx.com"
  20. 117.121.32.185 - - - [14/May/2011:20:28:50 +0800] "GET /homepage-market-conditio


  21. sed -n '/4\/May\/2011:20:28:10 +0800/,/14\/May\/2011:20:28:50 +0800/{
  22.         p
  23.         /14\/May\/2011:20:28:50 +0800/{
  24.                 :a
  25.                 n
  26.                 /14\/May\/2011:20:28:50 +0800/p
  27.                 /14\/May\/2011:20:28:50 +0800$/! b
  28.                 ta
  29.                 }
  30.         }' test

  31. 180.171.230.214 - - - [14/May/2011:20:28:10 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  32. 180.171.230.215 - - - [14/May/2011:20:28:14 +0800] "GET /promotion/gyp/20100602/maoyitong/index
  33. .....
  34. .....
  35. .....
  36. 110.75.196.130 - - - [14/May/2011:20:40:45 +0800] "GET / HTTP/1.1" 200 1
  37. 159.140.25.218 - - - [14/May/2011:20:28:50 +0800]  "http://xxx.com"
  38. 117.121.32.185 - - - [14/May/2011:20:28:50 +0800] "GET /homepage-market-conditio

复制代码

论坛徽章:
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
8 [报告]
发表于 2011-05-15 11:55 |只看该作者
回复 7# yinyuemi


sed 和 awk 对于 /foo1/,/foo2/ 的处理是有区别的。
  1. $ cat urfile                    
  2. xxx
  3. foo1 foo2
  4. xxx
  5. foo2
  6. xxx
  7. $ sed -n '/foo1/,/foo2/p' urfile
  8. foo1 foo2
  9. xxx
  10. foo2
  11. $ awk '/foo1/,/foo2/' urfile   
  12. foo1 foo2
复制代码

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
9 [报告]
发表于 2011-05-15 12:45 |只看该作者
回复 8# ly5066113


    多谢Tim兄指点,学习学习

论坛徽章:
1
双子座
日期:2013-10-17 00:46:45
10 [报告]
发表于 2011-05-15 23:27 |只看该作者
回复 8# ly5066113


    学习了~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP