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)
-> + JVM detection not finding JDK ... (2)
-> - stylus studio version 2011 pro... (1)
-> - WSDL 2.0 (1)
-> + Special characters in xml (2)
-> + cannot connect to mysql commun... (2)
-> + create a report from an existi... (2)
-> + Content not allowed in prolog (2)
-> + DB IInformix with database loc... (8)
-> + Stylus Report Designer (XML Re... (4)
-> - error: cos-nonambig: Content m... (1)
-> - UNIX .csv conversion and java ... (1)
-> + Nillable element, Validation e... (2)
-> + EDI Converter Error (2)
-> - CSV FILE INTO CARGO-IMP MESSAG... (1)
-> + BUG: Validation in piple will ... (2)
-> + Is there a 64-Bit Stylus Studi... (2)
-> + BUG: Read structure on SQL Ser... (3)
-> + [Customer Toyoto Motors Europe... (2)
-> - Get a schema for a JSON file (1)
-> + UNOC:4 forces converter to inp... (2)
-> - java class for xs:any elements (1)
-> + changing component separator (3)
-> + Output view disappeared (6)
-> + How to convert deeply nested X... (2)
-> + javax.net.ssl.SSLException (4)
-> + error converting .csv in a uni... (10)
-> + Menu bar disappeared (3)
-> - No Topic (1)
-> - What does "XML" stand for? So... (1)
-> - So XML is just HTML on steroid... (1)
-> + XHTML to XML conversion (2)
-> - Stylus Studio with DDTek xml c... (1)
-> + Installation fails (3)
-> + Is there a keyboard shortcut t... (2)
-> - Bug: Adding a scenario to an X... (1)
-> - Bug: Bug reporting outputs an ... (1)
-> - Tradacoms Invoice 9 Batch Quer... (1)
-> - problem with the product regis... (1)
-> + Help: Documentation... ends in... (2)
-> + How to install LIBxml2 (2)
-> - line numbers in validator outp... (1)
-> + Sharing Viollation in Stylus v... (5)
-> - support for asp.net in stylus... (1)
-> + how to use the latest java xml... (2)
-> - how to show xsd element relate... (1)
-> - Testing Stylus in a secure env... (1)
-> + How do you remove linemarkings... (3)
-> - Bug: Comment / Uncomment via C... (1)
-> + Setting escape (release) chara... (2)
-> + Xalan processor not showing up (2)
-> + Is there a keyboard shortcut t... (3)
-> - Modifying reports outside of S... (1)
-> + Run ALL Scenarios? (2)
-> + predefined macros ${ (4)
-> - TRADACOMS - EDI (1)
-> + SUM not working (3)
-> - Large xml file handling gives ... (1)
-> + 2011 Enterprise code folding f... (9)
-> + custom xml converter (3)
-> - Start Excel feter the mapping ... (1)
-> + Uninstall (2)
-> + xpath to compare two values fr... (2)
-> - xpath to compare two values fr... (1)
-> + SS2011 cannot save XML files u... (3)
-> + SS 2011 Enterprise saying 2010... (2)
-> + How to change the way whitespa... (7)
-> + Updating Relational Data Using... (4)
-> - Contract Stylus Studio help. ... (1)
-> + UTF_8 characters not displayed (6)
-> + Problem XSL to PDF ( dont reco... (2)
-> + HIPAA EDI - Looping question (4)
-> - HIPAA EDI - Looping question (1)
-> + Does XML Report support column... (2)
-> + Limited choice of XSL elements... (2)
-> + Single Source Publishing? (3)
-> - Stylus Stodio License (1)
-> - Stylus Stodio License (1)
-> + relax ng (3)
-> + having problem converting csv ... (8)
-> + error when selecting items fro... (2)
-> + CSV File to XML (3)
-> + Software registration - How to... (4)
-> - Software registration - How to... (1)
-> + .Net Saxon not supported by th... (2)
-> + How do I extend the Evaluation... (2)
-> + dst file (4)
-> - Flat File Custom XML conversio... (4)
-> ->Flat File Custom XML conv...
-> ->Flat File Custom XML conv...
-> ->Flat File Custom XML conv...
-> + converting ascii file to xml f... (2)
-> + Evaluation Copy of Stylus Stud... (8)
-> + Batch process for soap (4)
-> + Strange error when running gen... (5)
-> + Merge Files (2)
-> + Convert cvs to XML (2)
-> + Stylus studio 2010 crashes in ... (5)
-> + excel to text (2)
-> + licence key? (2)
-> + JVM Heap error (4)
-> + How Do I clean TXT File? (2)
-> + SS Web Service Call Tester Pay... (3)
-> - SS Web Service Call Tester Mic... (1)
-- Previous [421-440] [441-460] [461-480] 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
Stanley BowlingSubject: Flat File Custom XML conversion help
Author: Stanley Bowling
Date: 28 Sep 2010 12:59 PM
Hello,

I am reposting this in the correct section.

We have a flat file coming from our source system which represents child nodes as new lines in the same file. The child nodes can be identified by the first two characters of the line.
I need help to get the child nodes attached to the parent xml node. Can you help me figure out how this can be done. I have attached an example and the progress so far.

As in the example attached, the contact is displayed outside the customer,
<Customer>
<Type>A</Type>
<Number>1000</Number>
<FirstName>Casey</FirstName>
<LastName>Adams</LastName>
</Customer>
<Contact>
<ContactType>#C</ContactType>
<Number>585-433-1233</Number>
</Contact>
<Customer>...
I require the contact region to display as a child of customer like this.
<Customer>
<Type>A</Type>
<Number>1000</Number>
<FirstName>Casey</FirstName>
<LastName>Adams</LastName>
<Contact>
<ContactType>#C</ContactType>
<Number>585-433-1233</Number>
</Contact>
</Customer>
<Customer>...


Documentdemo(1).txt


DocumentDemo(1).conv


DocumentDemo(1).xml

Postnext
Ivan PedruzziSubject: Flat File Custom XML conversion help
Author: Ivan Pedruzzi
Date: 29 Sep 2010 12:35 AM
Hi Stanley,

You will need to post process the result, here one of possible solution using XQuery 1.1

Hope this helps
Ivan

<root>{
for tumbling window $items in /root/*
start $start when $start/self::Customer
end next $next when $next[self::Customer]
return
<customer>{
$start/*,
<Contacts>{
subsequence($items, 2)
}</Contacts>
}</customer>
}</root>


Postnext
Stanley BowlingSubject: Flat File Custom XML conversion help
Author: Stanley Bowling
Date: 29 Sep 2010 09:34 AM
Ivan,

Thanks for your quick reply. Your xquery does give the right results, however there is one more tweak I need. The xquery fills the contacts based on all items from subsequence($items, 2), however there may be a <note> or <comment> mixed in. Let me show this in an example.

<?xml version="1.0" encoding="utf-8"?>
<root>
<Customer>
<Type>A</Type>
<Number>1000</Number>
<FirstName>Casey</FirstName>
<LastName>Adams</LastName>
</Customer>
<Notes>
<Text>An example note</Text>
</Notes>
<Contact>
<ContactType>#C</ContactType>
<Number>585-433-1233</Number>
</Contact>
<Contact>
<ContactType>#C</ContactType>
<Number>111-111-1122</Number>
</Contact>
<Contact>
<ContactType>#C</ContactType>
<Number>222-333-4444</Number>
</Contact>
<Customer>
<Type>A</Type>
<Number>1001</Number>
<FirstName>William</FirstName>
<LastName>Test</LastName>
</Customer>
<Customer>
<Type>A</Type>
<Number>1002</Number>
<FirstName>Mary</FirstName>
<LastName>Troyer</LastName>
</Customer>
<Contact>
<ContactType>#C</ContactType>
<Number>777-777-7777</Number>
</Contact>
<Comments>
<Text>An example comment</Text>
</Comments>
</root>

The first customer has Notes located at position 2 and the third customer has Comments at position 3.

Can you help me figure out how to query/extract the items into the correct area.

Thanks again,
Stanley

Posttop
Ivan PedruzziSubject: Flat File Custom XML conversion help
Author: Ivan Pedruzzi
Date: 01 Oct 2010 01:17 AM

Assuming that you want comment and note inside customer

<root>{
for tumbling window $items in /root/*
start $start when $start/self::Customer
end next $next when $next[self::Customer]
return
<customer>{
$start/*,
subsequence($items, 2)[local-name()!='Contact'],
<Contacts>{
subsequence($items, 2)[local-name()='Contact']
}</Contacts>
}</customer>
}</root>

   
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.