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)
-> - Stylus Studio - Registrar en o... (1)
-> + Stylus Studio - Registrar en o... (2)
-> + Can a pipeline send a file by ... (2)
-> + After Updateing WIN10 to WIN11... (12)
-> + Where do I add the custom java... (3)
-> + Where is the Diagram tab? (5)
-> + Applying XSLT to Word DOCX/XML (2)
-> - CSV conversion via ConvertToXM... (1)
-> + Text symbols in SS not same as... (4)
-> + Exposing xquery as webservice ... (6)
-> + Syntax Identifier (2)
-> + Saving a Converted XML as an X... (5)
-> + Output document cannot be pars... (4)
-> - Archiving output from conversi... (1)
-> + EDIFACT guideline from Stylus ... (3)
-> + CSV file putting all the data ... (5)
-> + Can't install Home version 64b... (5)
-> + presale - Can I covers this sc... (5)
-> + Problem with UNB (5)
-> + Splitting EDIFACT files pipeli... (4)
-- [1-20] [21-40] [41-60] Next
+ Website Feedback (249)
+ XSLT Help and Discussion (7625)
+ XQuery Help and Discussion (2016)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Ric BeechSubject: Complex transactional CSV mapping
Author: Ric Beech
Date: 26 Apr 2012 02:09 PM
Originally Posted: 26 Apr 2012 02:07 PM
I grabbed a copy of this today and been looking through the forum trying to sort this myself, but I've gotten a bit stuck. What I'm trying to do is map a complex CSV file that has transactional information in it to XML. I can create a flat structure, but this will be difficult to work with later and thought that this may be something that is easily dealt with using something that I've not seen yet.

The data looks like the following

001|start of customer|custInfo1|custInfo2|
002|customer detail|detail1|...|
003|start of invoice|invoice1|...|
004|invoice detail|invoiceDetail1|...|
003|start of invoice|invoice1|...|
004|invoice detail|invoiceDetail1|...|
001|start of customer|custInfo1|custInfo2|

which should come out like

<xml>
<customer>
<custInfo1>custInfo1</custInfo1>
<custInfo2>custInfo2</custInfo2>
<invoice>
<invoice1>invoice1</invoice1>
...
<invoiceDetail>
<invoiceDetail1>invoiceDetail</invoiceDetail1>
</invoiceDetail>
</invoice>
<invoice>
<invoice1>invoice1</invoice1>
...
<invoiceDetail>
<invoiceDetail1>invoiceDetail</invoiceDetail1>
</invoiceDetail>
</invoice>
</customer>
</xml>

The problem is I don't see a way to define child objects other than by using regions, which looks like the wrong way to go.

Do I map each of the record types (001,002 etc.) with the node/pattern, let the converter do it's thing and spit out a flat version of the CSV in XML then write a very complex transformation later to assign the parent/child relationships, or is there an easier way to go?

Posttop
Ivan PedruzziSubject: Complex transactional CSV mapping
Author: Ivan Pedruzzi
Date: 09 May 2012 12:01 AM

Hi Rich

Attached to this message you have a solution that makes use of the built-in CSV converter and XQuery.

Hope this helps
Ivan Pedruzzi
Stylus Studio Team


Documentproject(1).zip

   
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.