免费注册 查看新帖 |

Chinaunix

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

[文本处理] 新手提问:如何抓取文件中的存在关联关系的数据 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-11-22 12:00 |只看该作者 |倒序浏览
文件内容:
JobA
条件:JobB

JobB
条件:JobE

JobC
条件:JobA

JobD
条件:无

JobE
条件:无

问题:如何把那些有关联条件的job提取出来呢?跪求大神,小弟感激不尽



论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
2 [报告]
发表于 2015-11-22 13:59 |只看该作者
不知道什么意思

论坛徽章:
0
3 [报告]
发表于 2015-11-22 19:04 |只看该作者
就把有条件关系的一系列job全部找出来,比如这里例子job之间的依赖关系是:JobE->JobB->JobA->JobC回复 2# haooooaaa


   

论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
4 [报告]
发表于 2015-11-22 19:42 |只看该作者
求大仙答疑解惑

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
5 [报告]
发表于 2015-11-22 20:29 |只看该作者
本帖最后由 haooooaaa 于 2015-11-22 22:09 编辑

回复 3# tmacxzk \

前面没看见你的 是 :分隔的,

用这个
  1. awk -F: '/条件/&&$2~/^Job/{if(!k){k=$2" "FILENAME}else if(k~FILENAME"|"$2){sub(FILENAME"|"$2,$2" "FILENAME,k)}}END{print k}' Job*
  2. JobE JobB JobA JobC
复制代码

论坛徽章:
20
卯兔
日期:2015-01-26 22:05:142015亚冠之萨济拖拉机
日期:2015-09-10 15:15:282015亚冠之阿尔希拉尔
日期:2015-09-25 17:37:53程序设计版块每日发帖之星
日期:2015-10-03 06:20:00程序设计版块每日发帖之星
日期:2015-12-09 06:20:00CU十四周年纪念徽章
日期:2015-12-17 09:07:15程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:342015亚冠之广州富力
日期:2015-08-27 19:29:56每日论坛发贴之星
日期:2015-08-26 06:20:002015亚冠之阿尔希拉尔
日期:2015-05-18 17:26:27
6 [报告]
发表于 2015-11-22 21:39 |只看该作者
本帖最后由 songyc_2015 于 2015-11-22 21:53 编辑

回复 1# tmacxzk
  1. awk -F'[\n::]' -vRS= 'function fac(con,jobb){
  2.     rs=""
  3.     for(job in a)
  4.     {
  5.         if(a[job]==con)
  6.         {
  7.             jobb=job
  8.             fs=fac(job,jobb)
  9.             sp=length(fs)?"->":""
  10.             rs=jobb sp fs
  11.             #rs=job"->"fac(job)
  12.         }
  13.     }
  14.     return rs
  15. }
  16. {
  17.     a[$1]=$3
  18. }
  19. END{
  20.     for(s in a)
  21.     {
  22.         if(a[s]=="无")
  23.         {
  24.             y=fac(s,"")
  25.             if(length(y))print s"->"y
  26.         }
  27.     }
  28. }' file
  29. JobE->JobB->JobA->JobC
复制代码

评分

参与人数 1信誉积分 +10 收起 理由
substr函数 + 10 赞一个!

查看全部评分

论坛徽章:
20
卯兔
日期:2015-01-26 22:05:142015亚冠之萨济拖拉机
日期:2015-09-10 15:15:282015亚冠之阿尔希拉尔
日期:2015-09-25 17:37:53程序设计版块每日发帖之星
日期:2015-10-03 06:20:00程序设计版块每日发帖之星
日期:2015-12-09 06:20:00CU十四周年纪念徽章
日期:2015-12-17 09:07:15程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:342015亚冠之广州富力
日期:2015-08-27 19:29:56每日论坛发贴之星
日期:2015-08-26 06:20:002015亚冠之阿尔希拉尔
日期:2015-05-18 17:26:27
7 [报告]
发表于 2015-11-22 22:23 |只看该作者
本帖最后由 songyc_2015 于 2015-11-22 22:25 编辑

回复 5# haooooaaa @tmacxzk
多个文件?不是一个?

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
8 [报告]
发表于 2015-11-23 09:20 |只看该作者
回复 7# songyc_2015


    这个,,,还真以为是多个文件,


如果一个。。。
  1. awk -F '[::]' '/条件/&&$2~/^Job/{if(!k){k=$2" "a}else if(k~a"|"$2){sub(a"|"$2,$2" "a,k)}}/^Job/{a=$1}END{print k}' file
  2. JobE JobB JobA JobC
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP