免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: ljt2k
打印 上一主题 下一主题

[文件目录] 脚本能实现显示树型结构吗? [复制链接]

论坛徽章:
6
摩羯座
日期:2013-08-24 10:43:10狮子座
日期:2013-08-25 10:27:06天秤座
日期:2013-09-11 20:28:44午马
日期:2014-09-28 16:06:0015-16赛季CBA联赛之八一
日期:2016-12-19 13:55:0515-16赛季CBA联赛之天津
日期:2016-12-20 14:01:23
11 [报告]
发表于 2013-08-08 08:17 |只看该作者
@ljt2k不用考虑哪种情况?哪种情况不是树结构。

论坛徽章:
0
12 [报告]
发表于 2013-08-08 09:20 |只看该作者
cao627 发表于 2013-08-08 08:17
@ljt2k不用考虑哪种情况?哪种情况不是树结构。




@rdcwayx
不是长久之计
100-103
101-102
103-104
105-100
107
100-101

如果是这样的文本呢?


---我说的不对,你说的这种也是树结构,但我的配置文件还没有这么复杂,从上往下,是一级一级的,先出现的都是父节点,不会有
105-100 这种对之前的父节点,又发现新的父节点。

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
13 [报告]
发表于 2013-08-08 09:31 |只看该作者
我来看展览

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
14 [报告]
发表于 2013-08-08 10:40 |只看该作者
ljt2k 发表于 2013-08-07 19:31
源文件a.cfg,记录的是父节点和子节点的关系(左边为父节点):
100-101
101-102


好像有人写过类似的树形输出了,你可以参考一下。
@大红机器
http://bbs.chinaunix.net/forum.p ... ;page=1#pid22322314

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
15 [报告]
发表于 2013-08-08 17:58 |只看该作者
换一个思路来做:
  1. [seesea@UC tree]$ cat a.cfg
  2. 100-101
  3. 101-102
  4. 100-103
  5. 103-104
  6. 105-106
  7. 107
  8. [seesea@UC tree]$ awk -F'-' '{for(i in ar) {if(ar[i] ~ $1"$") {ar[j++]=ar[i]"/"$2; next;} } ar[j++]=$1"/"$2}; END{for (i in ar) {system("mkdir -p " ar[i]);} system("tree"); for(i in ar) {split(ar[i], ar2, "/"); system("rm -r "ar2[1]" 2>/dev/null");}}' a.cfg
  9. .
  10. |-- 100
  11. |   |-- 101
  12. |   |   `-- 102
  13. |   `-- 103
  14. |       `-- 104
  15. |-- 105
  16. |   `-- 106
  17. |-- 107
  18. `-- a.cfg

  19. 8 directories, 1 file
复制代码

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
16 [报告]
发表于 2013-08-08 18:30 |只看该作者
回复 15# seesea2517


    有想法,涨姿势了,学习

论坛徽章:
0
17 [报告]
发表于 2013-08-08 21:02 |只看该作者
seesea2517 发表于 2013-08-08 17:58
换一个思路来做:



多谢!

论坛徽章:
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
18 [报告]
发表于 2013-08-09 03:11 |只看该作者
本帖最后由 rubyish 于 2013-08-08 23:21 编辑

多谢!

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
19 [报告]
发表于 2013-08-09 09:54 |只看该作者
回复 16# 关阴月飞


    也不是有什么想法啦,系统有这个功能,就想着直接让系统来画树图啦。

论坛徽章:
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
20 [报告]
发表于 2013-08-10 00:07 |只看该作者
给个:
help:
  1. # perl abc.pl data      # for terminal only
  2. # perl abc.pl -s data   
  3. # -l  sort lexically    perl abc.pl -l data
  4. # -n  sort numerically  perl abc.pl -n data
  5. # -s  for save          perl abc.pl -s data > save
  6. # OK        perl abc,pl -n -s > save
  7. # OK        perl abc,pl -l -s > save
  8. # Don't do it       # perl abc,pl    data > save
  9. # Don't do it       # perl abc,pl -n data > save
  10. # Don't do it       # perl abc,pl -l data > save
复制代码
  1. #!/usr/bin/perl
  2. use 5.018;
  3. my ( $F, %H, %L, $S, %O ) = pop;
  4. my @LP = ( '+-- ', '|   ', '    ', '|-- ', qr/^[^\s+\|]/ );
  5. my @LT = ( '└── ', '│   ', '    ', '├── ', qr/^[^\s└│]/ );
  6. my @LH = qw/M L N H R/;
  7. my %S  = ( l => 'cmp', n => '<=>' );

  8. map { /-([snl])/ and $1 eq 's' ? $O{$1}++ : ( $O{S} = $1 ) } @ARGV;
  9. @ARGV = ($F);
  10. @L{@LH} = $O{s} ? @LP : @LT;

  11. sub L {
  12.   my ( $h, $k ) = @_;
  13.   return [$k] unless defined $h->{$k};
  14.   map [ $k, @$_ ], map L( $h->{$k}, $_ ), keys %{ $h->{$k} }}

  15. sub F {
  16.   my ( $i, $j, $P ) = @_;
  17.   $P->[$i][$j] ne $L{N} and $P->[$i-1][$j] eq $L{M}
  18.   and $P->[$i-1][$j] = $L{H} }

  19. sub S { my $max = shift;
  20.   eval 'sub { '
  21.     . join( '||', map '$a->['.$_.']'.$S{$O{S}}.'$b->['."$_]", 1 .. $max - 1 )
  22.     . '}'; }

  23. map { delete $H{$_} }
  24.   map { $H{ $_->[0] }{ $_->[1] } = $H{ $_->[1] }; $_->[1] }
  25.   map { my ( $A, $B ) = ( split( /[-\n]/ ), '' );
  26.     $H{$A}{$B} = undef; [ $A, $B ] } <>;

  27. for my $k ( sort keys %H ) {
  28.   my ( $end, $max, @a, @P, %h ) = ( 0, 0, L \%H, $k );
  29.   if ( $O{S} ){
  30.     $max < @$_ and $max = @$_ for @a;
  31.     my $it = S $max;
  32.     @a = sort $it @a; }

  33.   for my $i (@a) {
  34.     for my $j ( 0 .. $#{$i} ) {
  35.       $i->[$j] or next;
  36.       $h{$j} and $h{$j} eq $i->[$j] and next;
  37.       $P[@P][$j] = $i->[$j];
  38.       $h{$j} = $i->[$j]; }}

  39.   $P[$_][1] and $end = $_ and last for reverse 0 .. $#P;

  40.   for my $i ( 0 .. $#P ) {
  41.     for my $j ( 0 .. $#{ $P[$i] } - 1 ) {
  42.       $j or $P[$i][$j] = $P[$i][$j+1] ? $L{M} : $i <= $end
  43.         ? $L{L} : $L{N} and F $i, $j, \@P and next;
  44.       my ( $G, $T, $H ) = ( 0, 0 );
  45.       $P[$_][$j+1] and $G = $_ and last for $i + 1 .. $#P;
  46.       $H = ( $G and $j < $#{ $P[$G-1] } ) ? $L{L} : $L{N};
  47.       $P[$i][$j] = $P[$i][$j+1] ? $L{M} : $H;
  48.       F $i, $j, \@P; }}

  49.   say map { ( /$L{R}/ ? $L{H} : $L{L} ) . $_ } join '', @$_ for @P; }
复制代码

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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP