当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 10 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-29 11:38 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
代码:
#noticep{ margin:0 10px; width:660px; background:url(http://mobile.qq.com:8080/web_mobile/mobile_res/mobile2009/images/double_line.gif) repeat-x bottom; padding-bottom:20px; }

比如上面这是一行,我要得到图片连接部分。

另外,在sed grep awk 里有环视的吗


_________________
Say hello to everyday!


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-29 12:44 
头像

注册: 2007-09-29 3:09
帖子: 5773
送出感谢: 0 次
接收感谢: 3
代码:
echo "#noticep{ margin:0 10px; width:660px; background:url(http://mobile.qq.com:8080/web_mobile/mobile_res/mobile2009/images/double_line.gif) repeat-x bottom; padding-bottom:20px; }" |sed -r "s|.+(http://[A-Za-z0-9_./:]+).+|\1|g"


这样子的么?


_________________
HUNT Unfortunately No Talent...


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-29 20:45 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
:em21 :em21

我刚刚手工把链接改了。好大的工程啊。。 :em20 :em20


_________________
Say hello to everyday!


页首
 用户资料  
 
4 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-29 20:51 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
引用:
sed -r "s|.+(http://[A-Za-z0-9_./:]+).+|\1|g"

HuntXu, 你写的sed我有点不太懂,可以帮我解释下吗。
第一处,| 竖线是什么?书上讲的是/斜线啊,是不是当有 -r 时要用竖线
第二处,\1是什么啊,是指前面匹配的第一的括号内的东西的吗?


_________________
Say hello to everyday!


页首
 用户资料  
 
5 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-29 23:52 
头像

注册: 2007-09-29 3:09
帖子: 5773
送出感谢: 0 次
接收感谢: 3
1.竖线和斜线一样,分割符而已...因为链接里有斜线,如果用斜线做分割符会有一堆转义的"\/"...
2.是


_________________
HUNT Unfortunately No Talent...


页首
 用户资料  
 
6 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-30 8:57 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
thx :em01


_________________
Say hello to everyday!


页首
 用户资料  
 
7 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-30 9:23 
头像

注册: 2007-11-19 21:51
帖子: 6956
地址: 成都
送出感谢: 0 次
接收感谢: 4
这样不是更简单么?
代码:
echo "#noticep{ margin:0 10px; width:660px; background:url(http://mobile.qq.com:8080/web_mobile/mobile_res/mobile2009/images/double_line.gif) repeat-x bottom; padding-bottom:20px;}"|awk -F'[()]' '{print $2}'


页首
 用户资料  
 
8 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-30 9:32 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
原来awk的分割符还可以是这样的。

可以是正则表达式的吗,试试


_________________
Say hello to everyday!


页首
 用户资料  
 
9 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-31 5:51 

注册: 2008-05-24 8:30
帖子: 1453
送出感谢: 2
接收感谢: 30
代码:
grep -o "http://[^)]*"


页首
 用户资料  
 
10 楼 
 文章标题 : Re: 在shell里怎么得到正则匹配的部分啊
帖子发表于 : 2009-03-31 16:22 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
aerofox 写道:
代码:
grep -o "http://[^)]*"

原来grep还有o这个选项,受教了,thanks


_________________
Say hello to everyday!


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 10 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译