免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2047 | 回复: 4

如何匹配指定字符串前面的指定内容 [复制链接]

论坛徽章:
0
发表于 2008-05-05 15:43 |显示全部楼层

  1. 219.233.117.180 - - [05/May/2008:09:13:04 +0800] "GET /images/header/header_fav.jpg HTTP/1.1" 304 - "http://www.xxx.xxx/01070164/ha.htm" "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)"
复制代码


类似这样的日志,我要达到的目标是匹配/ha.htm前面的两个斜杠之间的内容,也就是01070164。

用简单的awk可以实现,但是问题是http://www.xxx.xxx/01070164/ha.htm这个字符串有时候出现在这个日志的其他地方,也就是出现的地方不固定,不知道应该如何取,谢谢。。。。。

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2008-05-05 15:58 |显示全部楼层

回复 #1 Dreamhat 的帖子

  1. $ grep -Eo '/[^/]*/ha\.htm' urfile
复制代码

论坛徽章:
0
发表于 2008-05-05 16:04 |显示全部楼层
其他地方?
限定第8列不可以吗?
awk -W re-interval
match($8, /\/([0-9]{8})\/ha\.htm$/, s)  ===> s[1]

论坛徽章:
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
发表于 2008-05-05 16:59 |显示全部楼层
sed 's|/ha\.htm.*||;s|.*/||' urfile

论坛徽章:
0
发表于 2008-05-05 18:25 |显示全部楼层
谢谢楼上几位,两个都可以用。。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

SACC2019中国系统架构师大会

【数字转型 架构演进】SACC2019中国系统架构师大会,7折限时优惠重磅来袭!
2019年10月31日~11月2日第11届中国系统架构师大会(SACC2019)将在北京隆重召开。四大主线并行的演讲模式,1个主会场、20个技术专场、超千人参与的会议规模,100+来自互联网、金融、制造业、电商等领域的嘉宾阵容,将为广大参会者提供一场最具价值的技术交流盛会。

限时七折期:2019年8月31日前


----------------------------------------

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP