免费注册 查看新帖 |

Chinaunix

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

sed 匹配网站问题 (已解决) [复制链接]

论坛徽章:
0
发表于 2010-04-30 20:46 |显示全部楼层
本帖最后由 luo118 于 2010-05-02 12:35 编辑

sed 匹配网站问题

源文如下

  1. <VirtualHost *:80>
  2. ServerAdmin [email]webmaster@test.com[/email]
  3. DocumentRoot /home/vhost/test/public_html
  4. ServerName test.com
  5. ServerAlias [url]www.test.com[/url]
  6. ErrorLog logs/test.com-error_log
  7. TransferLog logs/test.com-access_log
  8. </VirtualHost>

  9. <VirtualHost *:80>
  10. ServerAdmin [email]webmaster@abc.com[/email]
  11. DocumentRoot /home/vhost/abc/public_html
  12. ServerName abc.com
  13. ServerAlias [url]www.abc.com[/url]
  14. ErrorLog logs/abc.com-error_log
  15. TransferLog logs/abc.com-access_log
  16. </VirtualHost>
复制代码
我的意思是,在虚拟主机中,找到 abc.com 的域名,把abc.com 整个虚拟主机输出。格式不变如下:

  1. <VirtualHost *:80>
  2. ServerAdmin [email]webmaster@abc.com[/email]
  3. DocumentRoot /home/vhost/abc/public_html
  4. ServerName abc.com
  5. ServerAlias [url]www.abc.com[/url]
  6. ErrorLog logs/abc.com-error_log
  7. TransferLog logs/abc.com-access_log
  8. </VirtualHost>
复制代码

论坛徽章:
0
发表于 2010-04-30 20:49 |显示全部楼层
sed -n '/\<VirtualHost\>/{/abc.com/},/\<VirtualHost\>/p' datafile;
提示用法不对。
所以请高手门指点一下。

论坛徽章:
0
发表于 2010-04-30 20:59 |显示全部楼层
回复 2# luo118


    为什么一定要用sed呢
  1. grep -A4 -B3  "ServerName abc.com" file
复制代码

论坛徽章:
0
发表于 2010-04-30 21:31 |显示全部楼层
awk 'BEGIN{RS = "\n\n\n+"}/abc/'

评分

参与人数 1可用积分 +2 收起 理由
luo118 + 2 THX

查看全部评分

论坛徽章:
0
发表于 2010-05-01 00:07 |显示全部楼层
回复 3# where27


    谢谢的回复,因为行数是不定的,有可在前有5行,或后面有7-10行。 所以一定要在一个范围内。不用管它多少行。

论坛徽章:
0
发表于 2010-05-01 00:11 |显示全部楼层
回复 4# iori809


    你方法你试过吗?好像没有起效,把所有内容都读出来,

还有nnn+ 是指3行中的abc 吧。。。

大家看看有没有更好的方法。谢谢!

论坛徽章:
0
发表于 2010-05-01 09:27 |显示全部楼层
我认为4楼的方法是可以的,你再仔细的看看

论坛徽章:
0
发表于 2010-05-01 13:37 |显示全部楼层
本帖最后由 where27 于 2010-05-01 13:49 编辑

如果每个虚拟主机之间都有空行分隔的话,4楼的方法是可以的,不过应该是两个\n吧。没有空行分隔就不行了

论坛徽章:
30
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3719周年集字徽章-19
日期:2019-08-27 13:31:2619周年集字徽章-CU
日期:2019-09-08 23:26:25
发表于 2010-05-01 14:00 |显示全部楼层
回复 6# luo118


4楼代码可行,你测试的时候用的哪个版本的awk啊?
\n\n\n+是指设置RS为三个或三个以上的newline

论坛徽章:
0
发表于 2010-05-01 14:04 |显示全部楼层
本帖最后由 where27 于 2010-05-01 14:06 编辑

回复 6# luo118
  1. sed -e '/^</,/Host>$/{H;//!d}' -e 'x;/abc.com/!d' file
复制代码
第一部分把虚拟主机的内容存到缓冲空间,第二部分判断虚拟主机里是否包含abc.com,包含则打印。
  1. awk 'BEGIN{RS="\n\n+"}/abc.com/' file
复制代码
这个是抄袭4楼呆呆的,不过得要每个虚拟主机都有空行分隔才好使,没有空行分隔的话就用sed吧

评分

参与人数 1可用积分 +2 收起 理由
luo118 + 2 right

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会 限时8.5折

【架构革新 高效可控】2020年8月17日~19日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP