免费注册 查看新帖 |

Chinaunix

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

怎样有效的实现这样的截取操作? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-12 10:00 |只看该作者 |倒序浏览

message:
     email-name/
    /home/usr/John/work/pros/address/emailname1*%/emailmes/temp/1.2
    /home/usr/Alice/work/pros/address/emailname1*%/emailmes/temp/1.1
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.8
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.7
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.6
    /home/usr/grace/file/ftp/address/emailname3*%/emailmes/temp/1.2




上面的一些信息是重定向之后生成的文件,在每个"/home"的前面都是一个4位的tab键,我现在想做的就是:
以第一行为例,截取出"work/pros/address/emailname1"和"1.2",然后每行都是在用户后要截取这样的信息(如第二行"work/pros/address/emailname1"和"1.1"),大家看看这样的截取用什么样的命令来操作呢?谢谢^

论坛徽章:
3
CU大牛徽章
日期:2013-03-13 15:29:07CU大牛徽章
日期:2013-03-13 15:29:49CU大牛徽章
日期:2013-03-13 15:30:19
2 [报告]
发表于 2009-07-12 10:44 |只看该作者
  1. sed '1,2d;s#/home/usr/*/##g' file|sed 's#\(.*\)\*%.*/\(.*\)#\1 \2#g'
复制代码

论坛徽章:
0
3 [报告]
发表于 2009-07-12 15:52 |只看该作者
  1. awk -F "*" '/\/home/{sub(/\t+\/home\/usr\//,"",$1);print $1,M[split($NF,M,"/")]}' file
复制代码

[ 本帖最后由 ywlscpl 于 2009-7-12 16:01 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2009-07-13 01:37 |只看该作者

回复 #2 MYSQLER 的帖子

s#/home/usr/*/##g 用得不对, 没去掉John/

论坛徽章:
0
5 [报告]
发表于 2009-07-13 09:54 |只看该作者
try

sed  "1,2d;  s#.*/home\/usr/[^\/]*/\(.*emailname[0-9]\+\).*\/\(.*\)#\1   \2#" urfile

论坛徽章:
0
6 [报告]
发表于 2009-07-13 10:04 |只看该作者
sed 's#/home/usr/[^/]*##g;s#\*%[^0-9]*#\t#g' f

论坛徽章:
0
7 [报告]
发表于 2009-07-13 13:19 |只看该作者

  1. sed -n '3,${s#^[ \t]*/home/usr/[^/]*/##;s#\*.*/# #p}' URFILE
复制代码

论坛徽章:
0
8 [报告]
发表于 2009-07-13 23:39 |只看该作者
          /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.8
        /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.7
        /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.6


好像这样截取出来的还是有重复的啊,对于这三行,有用的信息只是file/addre/emailname21.8,其他的两行就不用了,这样是咋实现的呢?

[ 本帖最后由 kszz0402940 于 2009-7-13 23:41 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2009-07-14 00:38 |只看该作者

回复 #8 kszz0402940 的帖子

[W]cat 2
   /home/usr/John/work/pros/address/emailname1*%/emailmes/temp/1.2
    /home/usr/Alice/work/pros/address/emailname1*%/emailmes/temp/1.1
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.8
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.7
    /home/usr/grace/file/addre/emailname2*%/emailmes/temp/1.6
    /home/usr/grace/file/ftp/address/emailname3*%/emailmes/temp/1.2
[W]
[W]awk -F'/' '{for(i=5;i<(NF-1);i++)printf $i"/"}{print $NF"\n"}' 2
work/pros/address/emailname1*%/emailmes/1.2

work/pros/address/emailname1*%/emailmes/1.1

file/addre/emailname2*%/emailmes/1.8

file/addre/emailname2*%/emailmes/1.7

file/addre/emailname2*%/emailmes/1.6

file/ftp/address/emailname3*%/emailmes/1.2

是这样吗?

论坛徽章:
0
10 [报告]
发表于 2009-07-14 13:05 |只看该作者

回复 #8 kszz0402940 的帖子

你前面并没说明有这个要求啊。

  1. awk -F"*%" 'NR>2{gsub("[ \t]*/home/usr/[^/]*/","",$1); gsub(".*/","",$2); a[$1]=($2>a[$1])?$2:a[$1]}END{for(i in a) print i,a[i]}' URFILE
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP