java


convert JSON to XML using XSLT 3 in java


When i was trying to transform JSON with XSLT to XML I am not able to transform, it is throwing the prolog exception, when i put the Json in tags i am able to transform. Can any one give an example how to transform from Json to XML with XSLT3.0.
Here's one example using json-to-xml(). It processes all json files in a specified directory (collection param).
I've also used json-doc() with uri-collection() and map:get() to process very simple json files.
JSON (File "so.json" based on the JSON in the question How to convert json to xml using xslt)
{"Order": {
"InvestmentAccount": {"AccountNumber": "10"},
"Parcel": {
"Limit": "0",
"ExpiryDate": "1900-01-01T00:00:00",
"Asset": [
{
"Open": "25.15",
"High": "25.15",
"Low": "25.11",
"Close": "25.87"
},
{
"Open": "25.15",
"High": "25.15",
"Low": "25.11",
"Close": "25.87"
}
]
},
"OrderDate": "2012-10-11T21:46:03.6489906+11:00"
}}
XSLT 3.0 (Tested using Saxon-HE 9.7.0.8J from the command line specifying init as the initial template.)
<xsl:stylesheet version="3.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:map="http://www.w3.org/2005/xpath-functions/map"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs map">
<xsl:output indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:param name="collection" select="'file:///C:/some/dir'"/>
<xsl:template match="#*|node()">
<xsl:copy>
<xsl:apply-templates select="#*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template name="init">
<xsl:for-each select="uri-collection(concat($collection,'?select=*.json'))">
<xsl:variable name="uri" select="."/>
<xsl:variable name="filename" select="tokenize($uri,'/')[last()]"/>
<xsl:message>Processing json file: <xsl:value-of select="$filename"/>...</xsl:message>
<xsl:variable name="json" select="unparsed-text($uri)"/>
<xsl:result-document href="{substring-before($filename,'.')}.xml">
<xsl:apply-templates select="json-to-xml($json)"/>
</xsl:result-document>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
XML Output ("so.xml")
<map xmlns="http://www.w3.org/2005/xpath-functions">
<map key="Order">
<map key="InvestmentAccount">
<string key="AccountNumber">10</string>
</map>
<map key="Parcel">
<string key="Limit">0</string>
<string key="ExpiryDate">1900-01-01T00:00:00</string>
<array key="Asset">
<map>
<string key="Open">25.15</string>
<string key="High">25.15</string>
<string key="Low">25.11</string>
<string key="Close">25.87</string>
</map>
<map>
<string key="Open">25.15</string>
<string key="High">25.15</string>
<string key="Low">25.11</string>
<string key="Close">25.87</string>
</map>
</array>
</map>
<string key="OrderDate">2012-10-11T21:46:03.6489906+11:00</string>
</map>
</map>
Since I'm doing an xsl:apply-templates along with the identity transform, the XML from json-to-xml() is output unchanged. I can easily add templates to transform that XML into something else. (Be sure to pay attention to the http://www.w3.org/2005/xpath-functions default namespace.)

Related Links

Can method overloading be used without knowing the type at compile time?
Fitness list replacing elements,optimization
Write a plugin for SonarPython
Two result sets causing Null Pointer in Java
Passing non-printable ascii codes as java argument
Need help choosing a robust archive format
Can I configure both HTML and Spring Data REST JSON on the same URI?
Java parse Date from string [duplicate]
Java, Apache HttpClient, TLSv1.2 & OpenJDK 7
Java how to take second element of array
What is the purpose of a Buffer in Java?
opencsv creating empty csv
Java 8 find first instance of value in multidimensional array of objects
Java - Recursively count occurrences of a word in a List
create a list of method references with different target object?
Is there a single XPath expression that can get a value from two different locations?

Categories

HOME
google-chrome-extension
pypi
heroku
reserved
path-finding
homebrew
relayjs
dot
bookshelf.js
at-command
sqlite3
opengl-es-2.0
wamp
azure-media-services
mouse
applepay
metatrader4
export-to-csv
collectd
windows-azure-storage
jplayer
gz
phaser
msp430
iron-router
text-rendering
java-3d
scriptcs
jasonette
kudan
wijmo
bootstrap-duallistbox
phpfox
maquette
log4js-node
srcset
microsoft-chart-controls
sql-server-2012-express
geopositioning
http-referer
suricata
multilingual
abstract-class
az-application-insights
uft-api
angularjs-factory
temporary-files
android-tabhost
texmaker
eclipse-gef
auto-update
rainbowtable
atomicity
prolog-setof
python-c-api
celery-task
togetherjs
worker-thread
knpmenubundle
angular-strap
sts-springsourcetoolsuite
adxstudio-portals
player
markojs
blackberry-10
ubuntu-10.04
make-install
dlna
fadeout
suffix-tree
ios8-today-widget
citrus-pay
emailrelay
graph-drawing
sniffer
web-controls
sonarqube5.1.2
pretty-print
directoryservices
python-green
wordpress-theme-customize
preferences
google-reader
android-radiobutton
dml
htmlcleaner
meteor-velocity
openlaszlo
pyhdf
dotnetnuke-5
qt-faststart
sharp-repository
html-editor
smtp-auth
pysimplesoap
buildr
recent-documents
.nettiers
filtered-index
asp.net-profiles
perfect-hash
sef
ctp4
temporal-database
phonon
thread-local-storage
port-number
windows-live-messenger

Resources

Database Users
RDBMS discuss
Database Dev&Adm
javascript
java
csharp
php
android
javascript
java
csharp
php
python
android
jquery
ruby
ios
html
Mobile App
Mobile App
Mobile App