NAME
XML::Filter::Dispatcher::AsStructHandler - convert SAX stream in to simple, data-oriented structure
SYNOPSIS
## Ordinarily used via the XML::Filter::Dispatcher's as_data_struct()
## built-in extension function for XPath
DESCRIPTION
This SAX2 handler builds a simple hash from XML. Text from each element and attribute is stored in the hash with a key of a relative path from the root down to the current element.
The goal is to produce a usable structure as simply and quickly as possible; use XML::Simple for more sophisticated applications.
The resulting data structure has one hash per element, one scalar per attribute, and one scalar per text string in each leaf element.
Warnings are emitted if any content other than whitespace is discarded.
The root element name is discarded.
If you are using namespaces, you must pass in the Namespaces
option, otherwise not. Using namespaces without a Namespaces
option or vice versa will not work.
Only start_document()
, start_element()
, characters()
, end_element()
, and end_document()
are provided; so all comments, processing instructions etc., are discarded.
Examples
This XML:
<root a="A">
<a aa1="AA1" aa2="AA2">
<b>B1</b>
<b>B2</b>
</a>
</root>
with no options produces this structure:
{
'@a' => 'A',
'a/@aa1' => 'AA1',
'a/@aa2' => 'AA2'
'a/b' => 'B2',
'' => '
B1
B2
', 'a' => ' B1 B2 ', }
Note 1: the name of the root element is discarded.
Note 2: the contents of the first <b>
element are not directly accessible; like standard Perl hashes, the later initialization overwrites the former. Much data oriented XML does not have this issue.
This XML:
<root
xmlns="default-ns"
xmlns:foo="foo-ns"
a="A"
foo:a="FOOA"
>
<a aa1="AA1" foo:aa1="AA2">
<b>B1</b>
<foo:b>B2</foo:b>
</a>
</root>
With these options:
XML::Filter::Dispatcher::AsStructHandler->new(
Namespaces => {
"" => "default-ns",
"bar" => "foo-ns",
},
Rules => [
"hash( root )" => sub { Dumper xvalue },
],
)
produces this structure:
{
'@a' => 'A',
'@bar:a' => 'FOOA',
'a/@aa1' => 'AA1',
'a/@aa2' => 'AA2'
'a/b' => 'B2',
'' => '
B1
B2
', 'a' => ' B1 B2 ', }
Methods
- new
-
see above.
- set_namespaces
-
$h->set_namespaces( prefix1 => uri1, );
AUTHOR
Barrie Slaymaker <barries@slaysys.com>
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 247:
You forgot a '=back' before '=head1'