Here's code running against a subtree from my system where I stuffed the tree output into a DATA section just to make a self-contained test case. I find it easier to read the YAML output than the Data::Dump output.
#!/usr/bin/perl # http://perlmonks.org/?node_id=1138867 use strict; use warnings; my @depth = {}; while(<DATA>) { /\S/ or last; /([| ]*?[|`]-- )?(.*)/ or next; my $level = length($1 // 0) / 4; $depth[$level]{$2} = $depth[$level + 1] = {}; } use YAML; print Dump $depth[0]; #use Data::Dump qw(pp); pp $depth[0]; __DATA__ wiki |-- RicksWiki_3_3 | |-- RCS | | |-- README,v | | |-- fast,v | | `-- go,v | |-- README | |-- cgi-bin | | |-- RCS | | | |-- server.pl,v | | | `-- wiki.pl,v | | |-- server.pl | | `-- wiki.pl | |-- doc | | |-- RCS | | | `-- index.html,v | | `-- index.html | |-- fast | |-- go | |-- history | | |-- CodeNotes,v | | |-- FormattingRules,v | | `-- PlayGround,v | |-- log.wiki | `-- pages | |-- CamelCase | |-- CodeNotes | |-- FormattingComments | |-- FormattingRules | |-- InstallInstructions | |-- MainPage | |-- OneMinuteWiki | |-- PlayGround | |-- RicksWikiFeatures | `-- SeedPage `-- RicksWiki_3_3.tgz 8 directories, 27 files
And here's the output:
--- wiki: RicksWiki_3_3: RCS: 'README,v': {} 'fast,v': {} 'go,v': {} README: {} cgi-bin: RCS: 'server.pl,v': {} 'wiki.pl,v': {} server.pl: {} wiki.pl: {} doc: RCS: 'index.html,v': {} index.html: {} fast: {} go: {} history: 'CodeNotes,v': {} 'FormattingRules,v': {} 'PlayGround,v': {} log.wiki: {} pages: CamelCase: {} CodeNotes: {} FormattingComments: {} FormattingRules: {} InstallInstructions: {} MainPage: {} OneMinuteWiki: {} PlayGround: {} RicksWikiFeatures: {} SeedPage: {} RicksWiki_3_3.tgz: {}
Note that "tree" in its basic form does not indicate whether a name is a file or a directory.
In reply to Re: file explorer type window
by Anonymous Monk
in thread file explorer type window
by perl1234
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |