XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
- Stylus Studio Technical Forum (14621)
-> + Unresponsive - Custom XML Conv... (2)
-> - Need Help defining Flat File w... (1)
-> + XML to Database (6)
-> + XSD path when associating to a... (3)
-> - Auto EDI File Translation (1)
-> + Need help parsing EDI and crea... (2)
-> + Bug in generating Xml from Dtd (7)
-> + Stylus Studio 15, install erro... (4)
-> + How to create UML from XSD (2)
-> + Java configuration (4)
-> + embedding/starting X15 dircet ... (2)
-> + Stylus X15 R2 environment crip... (5)
-> + Output Method TEXT does not wo... (6)
-> + CONV loses its format on re-op... (5)
-> - Trouble Converting 846 EDI Fil... (1)
-> + XML Catalog support - DITA (2)
-> + non-persistent VDI, App-V Lice... (2)
-> + Can we READ XLS file and Conve... (8)
-> + Mapping XML to XML (3)
-> + SS X15 - Getting Error with 45... (2)
-> + Optimal for DB to XML? (2)
-> + Issues exporting SQL Server ->... (2)
-> + need additinal field in XML (2)
-> + blinking (3)
-> + HELP ANYONE PLEASE (3)
-> + xi:include including include s... (2)
-> + Validating an XML file against... (2)
-> + XML to EDI Telco D.0 field len... (2)
-> + Converting EDIFACT to XML in c... (3)
-> + XSLT Transformation fails with... (4)
-> + StylusStudio X15 R2 java Auto ... (6)
-> + StylusStudio X15 Review - firs... (2)
-> + Stylus Studio X15 stuck on pro... (11)
-> + Error handling in Coverter fil... (2)
-> + RESTful Web Services in Stylus... (3)
-> + How to produce a human-readabl... (3)
-> + EDI 945 to AX (2)
-> + Help x15 failing install (5)
-> + XSD 1.0/1.1 schema validation ... (3)
-> + Java Runtime Environment 8.0 (3)
-> + Web Service Call to Oracle OSM... (2)
-> + Telco EDI to XML output on opt... (12)
-> + Authentication failed (2)
-> + no declaration found for eleme... (2)
-> + Component installation failed (5)
-> - Component installation failed (1)
-> - AUP to expire (1)
-> + Disable Automatic Updates in S... (2)
-> + Windows 7 64 bit compatibility (2)
-> + EDI 8.1 to 10.6 (2)
-> - Conerting EDI 8.1 to EDI 10.6 ... (1)
-> + Debugging with Java built-in p... (3)
-> + Moving Stylus Studio (2)
-> + When using an xsl:import file,... (3)
-> + Generate XSD file from XML fil... (2)
-> + Custom XML Conversion (2)
-> + Create XML from XSD schema fil... (4)
-> + Slimed by Microsoft Word 2010 (6)
-> + XML to EDI (Telco D.0) convers... (3)
-> + XML Pipeline Troubleshooting (10)
-> + Allow negative values in Telco... (7)
-> + Unable to add new arguments to... (2)
-> + Validating XML Document (4)
-> + Debugging with X15 and MSXML p... (2)
-> + Parameter values (5)
-> + Limit on size of schema/instan... (4)
-> + Enterprise 12r1-The decompress... (5)
-> + Lost my copy - how do I renew? (2)
-> + Add Arguments to JVM does not ... (10)
-> + Page-position='last' not inple... (3)
-> + Decode the base 64 encrypted f... (2)
-> + XALAN Processor (4)
-> + How to create an XSD for flat ... (4)
-> + xslt saxon processor failure (3)
-> + Variables window Context path ... (4)
-> + XLS Formatting Objects Preview... (7)
-> + German DTA File (2)
-> + EDI to XML and LX segment (2)
-> - The element with name "F0101Z2... (1)
-> + How to insert the current date... (3)
-> + XSD - XML Sample (4)
-> + XSD to XML (3)
-> + Java extension functions, Xala... (2)
-> + XML with XSD to PDF (7)
-> + mapped network drives not show... (5)
-> + WCF Message size (2)
-> + Re-imaged desktop/laptop lost ... (4)
-> + Relative path in Stylus Studio (2)
-> + & and & in web service cal... (8)
-> + Which JRE do I need now? (3)
-> + Line Delimitted File Conversio... (4)
-> + Generating EDI Data from XML w... (2)
-> + Generating an XML file using C... (2)
-> - Generating an XML file from (1)
-> + output document cannot be pars... (10)
-> + convert RELAX NG to xsd (2)
-> + Intended Use of a .sef File (3)
-> + Skipping invalid records on SQ... (5)
-> + EDI XML Converters Inserting "... (2)
-> + Trying to use EDI to XSD docum... (5)
-- Previous [121-140] [141-160] [161-180] Next
+ Website Feedback (249)
+ XSLT Help and Discussion (7625)
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Fred FooSubject: Nesting of records from fixed length file conversion
Author: Fred Foo
Date: 15 Jul 2012 07:46 PM
Originally Posted: 12 Jul 2012 10:25 PM
I'm using a custom converter to transform a fixed field layout file to xml. The sample input file has different record types, A and B. I've seen from some of the other posts how to use pattern matching to differentiate the record types, and that works well. What I can't seem to do is nest the B records within the A records (B recs should be a child of A). This is the input:
A1234567Diane
B100.00Shoes
B123.00Suit
A1234567Chris
B100.00Saucepan
B123.00Frying Pan

This is the output I'm getting from the conversion:
<ROOT>
<A>
<ACCTNO>1234567</ACCTNO>
<NAME>Diane</NAME>
</A>
<B>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Shoes</DESCRIPTION>
</B>
<B>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Suit</DESCRIPTION>
</B>
<A>
<ACCTNO>1234567</ACCTNO>
<NAME>Chris</NAME>
</A>
<B>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Saucepan</DESCRIPTION>
</B>
<B>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Frying Pan</DESCRIPTION>
</B>
</ROOT>

Is there a way of specifying the hierarchy of the output nodes in a custom conversion to xml? Here's what it should look like:
<ROOT>
<A>
<ACCTNO>1234567</ACCTNO>
<NAME>Diane</NAME>
<B>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Shoes</DESCRIPTION>
</B>
<B>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Suit</DESCRIPTION>
</B>
</A>

<A>
<ACCTNO>1234567</ACCTNO>
<NAME>Chris</NAME>
<B>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Saucepan</DESCRIPTION>
</B>
<B>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Frying Pan</DESCRIPTION>
</B>
</A>
</ROOT>

thanks

Postnext
Ivan PedruzziSubject: Nesting of records from fixed length file conversion
Author: Ivan Pedruzzi
Date: 13 Jul 2012 02:41 PM
Hi Fred,

You may need to use either XSLT or XQuery for performing these kind of tasks.

If you zip a sample of your input data and your .conv file we can get you started.

Hope this helps
Ivan Pedruzzi
Stylus Studio Team

Postnext
Fred FooSubject: Nesting of records from fixed length file conversion
Author: Fred Foo
Date: 15 Jul 2012 07:51 PM
Thanks Ivan. If it can't be done directly with the .conv, I'd like to do it with xquery if possible. I'll upload the .conv, and input and output files


UnknownfixedLength.zip

Postnext
Ivan PedruzziSubject: Nesting of records from fixed length file conversion
Author: Ivan Pedruzzi
Date: 16 Jul 2012 09:28 PM
The following query should help

Ivan Pedruzzi
Stylus Studio Team


declare variable $doc := doc("converter:fixedLength.conv?input.txt");

declare function local:tx($tx as element(*, xs:untyped)? ) as element(*, xs:untyped)*
{
let $next := $tx/following-sibling::*[1]
return
if (local-name($next) = 'TXN' ) then
(
$next,
local:tx($next)
)
else ()
};

<ROOT>
{
for $cust in $doc/ROOT/CUST
return
<CUST>
{
$cust/*
}
<Transactions>
{
local:tx($cust)
}
</Transactions>
</CUST>
}
</ROOT>


--------------------------
Result


<ROOT>
<CUST>
<ACCTNO>1234567</ACCTNO>
<NAME>Diane</NAME>
<Transactions>
<TXN>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Shoes</DESCRIPTION>
</TXN>
<TXN>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Suit</DESCRIPTION>
</TXN>
</Transactions>
</CUST>
<CUST>
<ACCTNO>1234567</ACCTNO>
<NAME>Chris</NAME>
<Transactions>
<TXN>
<AMOUNT>100.00</AMOUNT>
<DESCRIPTION>Saucepan</DESCRIPTION>
</TXN>
<TXN>
<AMOUNT>123.00</AMOUNT>
<DESCRIPTION>Frying Pan</DESCRIPTION>
</TXN>
</Transactions>
</CUST>
</ROOT>

Posttop
Fred FooSubject: Nesting of records from fixed length file conversion
Author: Fred Foo
Date: 17 Jul 2012 08:16 PM
Many thanks Ivan, that does the trick

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.