免费注册 查看新帖 |

Chinaunix

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

2个问题,实现一对多,然后 再多对一的表格可以吗,大侠们 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-03-12 03:19 |只看该作者 |倒序浏览
本帖最后由 zhxftj 于 2013-03-12 11:05 编辑

用hash ,数组都可, 请赐教, 是2个问题
Input file:
cluster1 loc1 。。。
cluster1 loc2 。。。
cluster1 loc3 。。。
cluster1 loc4 。。。
cluster2 loc5 。。。
cluster2 loc6 。。。
cluster2 loc7 。。。
relationship file:
group1 cluster1 loc1
group1 cluster1 loc2
group2 cluster 1 loc3
group2 cluster 1 loc4
group3 cluster2 loc5
group3 cluster2 loc6
group3 cluster2 loc7

有求,问题一1)将每组分别存成一个文件
结果如下,请打印出
文件1:
group1 cluster1 loc1 。。。
group1 cluster1 loc2。。。
文件2:
group2 cluster 1 loc3。。。
group2 cluster 1 loc4。。。
文件3:
group3 cluster2 loc5 。。。
group3 cluster2 loc6。。。
group3 cluster2 loc7 。。。

解释 一对多在于一个group 对应几个cluster 和 loc 组合,

问题2) 多对一, 是用一个特定的组合可以找到所在group
仅在一个文件中给出
cluster1 loc4。。。
cluster2 loc5。。。
cluster2 loc6。。。

请打印出
cluster1 loc4 group2。。。
cluster2 loc5 group3。。。
cluster2 loc6 group3。。。



论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
2 [报告]
发表于 2013-03-12 09:09 |只看该作者
本帖最后由 rubyish 于 2013-03-12 05:16 编辑

input
  1. cluster1 loc1 。。。
  2. cluster1 loc2 。。。
  3. cluster1 loc3 。。。
  4. cluster1 loc4 。。。
  5. cluster2 loc5 。。。
  6. cluster2 loc6 。。。
  7. cluster2 loc7 。。。
复制代码
rela
  1. group1 cluster1 loc1
  2. group1 cluster1 loc2
  3. group2 cluster1 loc3
  4. group2 cluster1 loc4
  5. group3 cluster2 loc5
  6. group3 cluster2 loc6
  7. group3 cluster2 loc7
复制代码
Q2
  1. cluster1 loc4。。。
  2. cluster2 loc5。。。
  3. cluster2 loc6。。。
复制代码
pl
  1. #!/usr/bin/perl
  2. my @files = qw/input rela Q2/;
  3. my ( $i, $r, $q ) = map { open my ($f), $_; $f } @files;
  4. my %i = map /(\w+\s+\w+)(.*)/, <$i>;
  5. my ( $n, $fh, %g ) = 'test';

  6. while (<$r>) {
  7.     chomp;
  8.     my ( $g, $c ) = split /\s+/, $_, 2;
  9.     $g =~ /(\d+)/;
  10.     open $fh, '>', 'DOC' . $1 if $n ne $1;
  11.     print $fh "$g $c$i{$c}\n";
  12.     ( $g{$c}, $n ) = ( $g, $1 );
  13. }

  14. s/(\w+\s+\w+\d+)/$1 $g{$1}/ and print while <$q>;
复制代码
  1. perl abc.pl
复制代码

论坛徽章:
0
3 [报告]
发表于 2013-03-12 10:04 |只看该作者
回复 2# rubyish
谢谢赐教 试下, 高手呀 :wink: ,呵呵

   

论坛徽章:
0
4 [报告]
发表于 2013-03-12 10:09 |只看该作者
回复 2# rubyish
工作了 ,厉害呀

我要是有钱,就 雇你当我的程序员,呵呵

哎。。。可惜呀 。。

   

论坛徽章:
0
5 [报告]
发表于 2013-03-12 10:31 |只看该作者
回复 1# zhxftj
诸位,map 太高深,有没有个,俺看的懂的实现方法呀,
我 的 最高水平也就 hash了。。。

  

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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP