I have a set of XML files to process, and currently I am using a DOM-oriented method to do so. However, because the files could get fairly large I'd like another method of processing them that doesn't mean putting the entire structure into memory.
A colleague suggested I use SAX and in particular SAX::Machines, which looks like it would do what I want to do quite easily. I have been looking for some examples of how to use SAX::Machines as well as the docs, and havent been coming up with much. My attempts to solve the problem using XML::Filter::DocSplitter and the other Machines modules have come to naught also.
My problem is that I am having real trouble getting into the SAX "frame of mind". I know what the problem is, I know a basic plan of action, but translating that into SAX code has turned out to be a real problem.
Here's a representitive of the structure of my XML:
<root> <name>Parent Name</name> <node><name>Node 1</name> <node><name>Node 2</name> <child id="2263583"> <start> <thing value="20001231945"/> </start> </child> </node></node> <node><name>Node 3</name> <node><name>Node 4</name> <child id="2274693"> <start> <thing value="20001231930"/> </start> </child> </node> </node> </root>
What I want to do is 'cut' the document into chunks at the deepest elements called 'node' (there can be either 1, 2 or 3 levels), take the contents of it (1 or more elements called 'child', and output those contents to a file name that is determined by what the values of the 'name' elements in it's ancestors are.
For example, the first 'child' element would be put into a file called 'ParentName_Node1_Node2.xml' or similar. So, the 'child' elements have to be aware of where they are in the hierarchy so they can be put into the relevant file. The last point that complicates it a little is that the xml should be placed as the last element of a file of the name IF it already exists; so that particular point stops me from using an 'in-memory' model, and suggests one that is stream or pipeline oriented (to avoid putting that file in memory).
So... I have been battling with this for a while now, and I see that my frame of mind seems to be wrong to solve the problem. Can somebody please point me in the right direction ?

In reply to Getting into a SAX frame of mind by jasonv

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.