use strict; use warnings; use Data::Dump qw/pp dd/; my $data= join "", ; use XML::Twig; $\="\n"; print "=== HANDLER:\n"; my $twig=XML::Twig->new( twig_handlers => { 'field[@name="doctext"]' => sub { print $_->gi,"Post: ",$_->child_text(0) }, 'author' => sub { print "ID: ", $_->att("id"); print "Name: ", $_->child_trimmed_text(0); }, }, ); $twig->parse($data); print "=== SIMPLIFIED:\n"; $twig=XML::Twig->new(); print pp $twig->parse( $data)->simplify(); __DATA__ note haukex <p>More fun facts! I once wrote a script to search a word list for words that make valid regexen which convert one valid word into another.</p> <c> $ perl -le 'print bangs =~s engender' bands $ perl -le 'print halved =~s avatar' halted $ perl -le 'print stove =~s evener' stone </c> 11100593 11100640 21 #### === HANDLER: ID: 830549 Name: haukex fieldPost:

More fun facts! I once wrote a script to search a word list for words that make valid regexen which convert one valid word into another.

$ perl -le 'print bangs =~s engender' bands $ perl -le 'print halved =~s avatar' halted $ perl -le 'print stove =~s evener' stone === SIMPLIFIED: { author => { 830549 => { content => "\nhaukex" } }, created => "2019-05-28 16:28:57", data => { field => { doctext => { content => "\n

More fun facts! I once wrote a script to search a word list for words that make valid regexen which convert one valid word into another.

\n\n\$ perl -le 'print bangs =~s engender'\nbands\n\$ perl -le 'print halved =~s avatar'\nhalted\n\$ perl -le 'print stove =~s evener'\nstone\n\n", }, parent_node => { content => "\n11100640" }, reputation => { content => "\n21" }, root_node => { content => "\n11100593" }, }, }, title => "Re^5: What does \$_ = qq~\"\$_\"~ do?", type => { 11 => { content => "\nnote" } }, updated => "2019-05-28 16:28:57", }