JSONに相当するXSLTはありますか?XSLTがXMLに対して行うように、JSONで変換を行うための何か。
JSONに相当するXSLTはありますか?XSLTがXMLに対して行うように、JSONで変換を行うための何か。
回答:
面白いアイデア。Googleで検索した結果、興味のあるページがいくつか見つかりました。
お役に立てれば。
JSONに相当するXSLT-候補のリスト(ツールと仕様)
XSLT for JSONをfn:json-to-xmlの目的で使用できます。
このセクションでは、XSLTを使用してJSONデータを処理できる機能について説明します。
jqはJSONデータのsedのようなものです。sed、awk、grepなどでテキストを操作するのと同じくらい簡単に、構造化データをスライス、フィルタリング、マッピング、変換できます。異なるOS用のインストールパッケージがあります。
JJは、JSONドキュメントから値を取得または更新するための高速で簡単な方法を提供するコマンドラインユーティリティです。これは、GJSONとSJSONの内部で動作します。
コマンドラインJSON処理ツール
- 新しい構文を学ぶ必要はありません
- プレーンJavaScript
- 書式設定と強調表示
- スタンドアロンバイナリ
jl( "JSONラムダ")は、JSONのクエリと操作のための小さな関数型言語です。
Javaで記述されたJSONからJSONへの変換ライブラリ。変換の「仕様」自体がJSONドキュメントです。
JSONをグリップ可能にします!gronはJSONを個別の割り当てに変換して、必要なものをgrepし、絶対パスを確認するのを容易にします。JSONの大きなblobを返すが、ひどいドキュメントがあるAPIの探索を容易にします。
jsonは、JSONを操作するための高速CLIツールです。これは、(node.js自体以外の)外部依存関係のない単一ファイルのnode.jsスクリプトです。
JSON-eは、JSONオブジェクトにコンテキストを埋め込むためのデータ構造パラメーター化システムです。中心的な考え方は、データ構造を「テンプレート」として扱い、別のデータ構造をコンテキストとして使用して変換し、出力データ構造を生成することです。
JSLTはJSON用の完全なクエリおよび変換言語です。言語設計は、jq、XPath、およびXQueryに触発されています。
JSONataは、JSONデータ用の軽量のクエリおよび変換言語です。XPath 3.1の「ロケーションパス」セマンティクスに触発されており、洗練されたクエリをコンパクトで直感的な表記で表現できます。
JSONデータを変換するための再帰的なパターンマッチングアプローチを提供します。変換は、JSONオブジェクトの構造と一致する一連のルールとして定義されます。一致が発生すると、ルールは変換されたデータを発行し、オプションで再帰的に子オブジェクトを変換します。
Jsawkはawkに似ていますが、JSONです。stdinから読み取ったJSONオブジェクトの配列を操作し、JavaScriptを使用してそれらをフィルタリングして、stdoutに出力される結果配列を生成します。
テストはドキュメントとして使用できますhttps://github.com/pasaran/yate/tree/master/tests
JSONPathを使用してオブジェクトリテラルからデータをプルし、テンプレートに基づいて新しいオブジェクトを生成します。
Staplingは、JSONオブジェクトのXSLTフォーマットを可能にするJavaScriptライブラリです。JavaScriptテンプレートエンジンとtext / htmlテンプレートを使用する代わりに、Staplingは、Ajaxと非同期で読み込まれ、クライアント側にキャッシュされたXSLTテンプレートを使用して、JSONデータソースを解析する機会を提供します。
JSONポインターは、JavaScript Object Notation(JSON)ドキュメント内の特定の値を識別するための文字列構文を定義します。
JSONPath式は常に、XPath式がXMLドキュメントと組み合わせて使用されるのと同じ方法でJSON構造を参照します
JSONのJSPathは、XMLのXPathに似ています。」
JSONiqの背後にあるインスピレーションの主な情報源はXQueryです。これは、これまでのところ、半構造化データのための成功した生産的なクエリ言語であることが証明されています
JOLTをお試しください。これは、Javaで記述されたJSONからJSONへの変換ライブラリです。
これは、「JSON-> XML-> XSLT-> XML-> JSON」ゲームをプレイしたくなかったために作成され、十分に複雑な変換にテンプレートを使用することは維持できません。
XSLTのようなテンプレートベースではありませんが、より簡潔です。たとえばname
、address
フィールドを配列に抽出するには:[.name, .address]
このチュートリアルでは、TwitterのJSON APIを変換する例を紹介しています(このマニュアルには多くの例があります)。
.. | .attr_name?
あなたが探しているものですか?(stedolan.github.io/jq/manual/#RecursiveDescent:..から)
XSLTは、http://www.w3.org/TR/xslt-30/#jsonにある JSONをサポートしています。
XMLは区切りトークンに山かっこを使用し、JSONは中かっこ、角かっこを使用します... I. e。XMLのトークン認識比較が少ないということは、XMLが宣言型変換に最適化されていることを意味しますが、スイッチステートメントのように比較が多いのは、速度上の理由から、スクリプト言語の命令コードが役立つ投機的分岐予測を想定しているためです。直接的な結果として、半構造化データのさまざまな組み合わせについて、XSLTおよびJavaScriptエンジンのパフォーマンスをレスポンシブページの一部としてベンチマークすることができます。無視できるデータペイロードの場合、変換はXMLシリアル化のないJSONでも同様に機能する可能性があります。W3の決定は、より良い分析に基づくべきです。
私は最近、JSONをスタイリングするために大好きなツールを見つけました:https : //github.com/twigkit/tempo。非常に使いやすいツール-私の意見では、XSLTよりも操作がはるかに簡単です-XPATHクエリは必要ありません。
ツールの欠如は、必要性の欠如が問題を招いていることを示唆しています。LinuxでのXまたはYのサポートにも同じことが当てはまります(なぜ、このような少数派のOS向けに高品質のドライバーやゲームを開発する必要があるのですか?そして、大手ゲーム会社やハードウェア会社が開発していないOSに注意を払うのはなぜですか?)。おそらく、XSLTとJSONを使用する必要がある人々は、JSONをXMLに変換するという、いくらか簡単な回避策を使用することになります。しかし、それは最適な解決策ではありませんね。
ネイティブJSON形式があり、それをブラウザーで「wysywyg」で編集する場合、XSLTは問題の適切な解決策ではありません。従来のjavascriptプログラミングでそれを行うと、頭痛の種になる可能性があります。
実際、XSLTに「石器時代」のアプローチを実装しました。サブストリング解析を使用して、テンプレートの呼び出し、子の処理など、JavaScriptのいくつかの基本的なコマンドを解釈しています。確かに、JSONオブジェクトを使用した変換エンジンの実装は、 XSLTを解析するための本格的なXMLパーサーを実装します。問題は、XMLテンプレートを使用してJSONオブジェクトを変換するには、テンプレートのXMLを解析する必要があることです。
JSONオブジェクトをXML(またはHTML、テキストなど)で変換するには、変換コマンドを識別するために使用する必要がある構文と特殊文字について慎重に検討する必要があります。それ以外の場合は、独自のカスタムテンプレート言語のパーサーを設計する必要があります。その道を歩んでいると、私はそれがきれいではないことをあなたに言うことができます。
更新(2010年11月12日):パーサーで数週間作業した後、私はそれを最適化することができました。テンプレートは事前に解析され、コマンドはJSONオブジェクトとして保存されます。変換ルールもJSONオブジェクトですが、テンプレートコードはHTMLとシェルコードに似た自作構文の組み合わせです。複雑なJSONドキュメントをHTMLに変換してドキュメントエディターを作成できました。コードはエディターの約1K行(プライベートプロジェクトのため、共有できない)であり、JSON変換コードの約990行です(反復コマンド、単純な比較、テンプレートの呼び出し、変数の保存と評価を含みます)。MITライセンスでリリースする予定です。参加したい場合はメールをください。
私はこれを中心に自分の小さなライブラリを書きました。
5.1処理モデル(XSLT REC) https://www.w3.org/TR/xslt#section-Processing-Model
可能な限り(とにかく)数行のJavaScriptコードで。
以下は、完全に重要な使用例です...
フィドル:https : //jsfiddle.net/YSharpLanguage/kj9pk8oz/10
(D.1ドキュメント例(XSLT REC)に 触発されましたhttps://www.w3.org/TR/xslt#section-Document-Example)
ここで:
var D1document = {
type: "document", title: [ "Document Title" ],
"": [
{ type: "chapter", title: [ "Chapter Title" ],
"": [
{ type: "section", title: [ "Section Title" ],
"": [
{ type: "para", "": [ "This is a test." ] },
{ type: "note", "": [ "This is a note." ] }
] },
{ type: "section", title: [ "Another Section Title" ],
"": [
{ type: "para", "": [ "This is ", { emph: "another" }, " test." ] },
{ type: "note", "": [ "This is another note." ] }
] }
] }
] };
var D1toHTML = { $: [
[ [ function(node) { return node.type === "document"; } ],
function(root) {
return "<html>\r\n\
<head>\r\n\
<title>\r\n\
{title}\r\n".of(root) + "\
</title>\r\n\
</head>\r\n\
<body>\r\n\
{*}".of(root[""].through(this)) + "\
</body>\r\n\
</html>";
}
],
[ [ function(node) { return node.type === "chapter"; } ],
function(chapter) {
return " <h2>{title}</h2>\r\n".of(chapter) + "{*}".of(chapter[""].through(this));
}
],
[ [ function(node) { return node.type === "section"; } ],
function(section) {
return " <h3>{title}</h3>\r\n".of(section) + "{*}".of(section[""].through(this));
}
],
[ [ function(node) { return node.type === "para"; } ],
function(para) {
return " <p>{*}</p>\r\n".of(para[""].through(this));
}
],
[ [ function(node) { return node.type === "note"; } ],
function(note) {
return ' <p class="note"><b>NOTE: </b>{*}</p>\r\n'.of(note[""].through(this));
}
],
[ [ function(node) { return node.emph; } ],
function(emph) {
return "<em>{emph}</em>".of(emph);
}
]
] };
console.log(D1document.through(D1toHTML));
...与える:
<html>
<head>
<title>
Document Title
</title>
</head>
<body>
<h2>Chapter Title</h2>
<h3>Section Title</h3>
<p>This is a test.</p>
<p class="note"><b>NOTE: </b>This is a note.</p>
<h3>Another Section Title</h3>
<p>This is <em>another</em> test.</p>
<p class="note"><b>NOTE: </b>This is another note.</p>
</body>
</html>
そして
フィドル:https : //jsfiddle.net/YSharpLanguage/ppfmmu15/10
ここで:
// (A "Company" is just an object with a "Team")
function Company(obj) {
return obj.team && Team(obj.team);
}
// (A "Team" is just a non-empty array that contains at least one "Member")
function Team(obj) {
return ({ }.toString.call(obj) === "[object Array]") &&
obj.length &&
obj.find(function(item) { return Member(item); });
}
// (A "Member" must have first and last names, and a gender)
function Member(obj) {
return obj.first && obj.last && obj.sex;
}
function Dude(obj) {
return Member(obj) && (obj.sex === "Male");
}
function Girl(obj) {
return Member(obj) && (obj.sex === "Female");
}
var data = { team: [
{ first: "John", last: "Smith", sex: "Male" },
{ first: "Vaio", last: "Sony" },
{ first: "Anna", last: "Smith", sex: "Female" },
{ first: "Peter", last: "Olsen", sex: "Male" }
] };
var TO_SOMETHING_ELSE = { $: [
[ [ Company ],
function(company) {
return { some_virtual_dom: {
the_dudes: { ul: company.team.select(Dude).through(this) },
the_grrls: { ul: company.team.select(Girl).through(this) }
} }
} ],
[ [ Member ],
function(member) {
return { li: "{first} {last} ({sex})".of(member) };
} ]
] };
console.log(JSON.stringify(data.through(TO_SOMETHING_ELSE), null, 4));
...与える:
{
"some_virtual_dom": {
"the_dudes": {
"ul": [
{
"li": "John Smith (Male)"
},
{
"li": "Peter Olsen (Male)"
}
]
},
"the_grrls": {
"ul": [
{
"li": "Anna Smith (Female)"
}
]
}
}
}
同等のJavaScript ...
XSLT 3.0 RECセクション14.4例:一般的な値に基づくノードのグループ化
(で:http : //jsfiddle.net/YSharpLanguage/8bqcd0ey/1)
Cf. https://www.w3.org/TR/xslt-30/#grouping-examples
どこ...
var cities = [
{ name: "Milano", country: "Italia", pop: 5 },
{ name: "Paris", country: "France", pop: 7 },
{ name: "München", country: "Deutschland", pop: 4 },
{ name: "Lyon", country: "France", pop: 2 },
{ name: "Venezia", country: "Italia", pop: 1 }
];
/*
Cf.
XSLT 3.0 REC Section 14.4
Example: Grouping Nodes based on Common Values
https://www.w3.org/TR/xslt-30/#grouping-examples
*/
var output = "<table>\r\n\
<tr>\r\n\
<th>Position</th>\r\n\
<th>Country</th>\r\n\
<th>City List</th>\r\n\
<th>Population</th>\r\n\
</tr>{*}\r\n\
</table>".of
(
cities.select().groupBy("country")(function(byCountry, index) {
var country = byCountry[0],
cities = byCountry[1].select().orderBy("name");
return "\r\n\
<tr>\r\n\
<td>{position}</td>\r\n\
<td>{country}</td>\r\n\
<td>{cities}</td>\r\n\
<td>{population}</td>\r\n\
</tr>".
of({ position: index + 1, country: country,
cities: cities.map(function(city) { return city.name; }).join(", "),
population: cities.reduce(function(sum, city) { return sum += city.pop; }, 0)
});
})
);
...与える:
<table>
<tr>
<th>Position</th>
<th>Country</th>
<th>City List</th>
<th>Population</th>
</tr>
<tr>
<td>1</td>
<td>Italia</td>
<td>Milano, Venezia</td>
<td>6</td>
</tr>
<tr>
<td>2</td>
<td>France</td>
<td>Lyon, Paris</td>
<td>9</td>
</tr>
<tr>
<td>3</td>
<td>Deutschland</td>
<td>München</td>
<td>4</td>
</tr>
</table>
同等のJavaScript ...
JSONiqの使用例セクション1.1.2。JSONのクエリのグループ化
(で:https : //jsfiddle.net/YSharpLanguage/hvo24hmk/3)
Cf. http://jsoniq.org/docs/JSONiq-usecases/html-single/index.html#jsongrouping
どこ...
/*
1.1.2. Grouping Queries for JSON
http://jsoniq.org/docs/JSONiq-usecases/html-single/index.html#jsongrouping
*/
var sales = [
{ "product" : "broiler", "store number" : 1, "quantity" : 20 },
{ "product" : "toaster", "store number" : 2, "quantity" : 100 },
{ "product" : "toaster", "store number" : 2, "quantity" : 50 },
{ "product" : "toaster", "store number" : 3, "quantity" : 50 },
{ "product" : "blender", "store number" : 3, "quantity" : 100 },
{ "product" : "blender", "store number" : 3, "quantity" : 150 },
{ "product" : "socks", "store number" : 1, "quantity" : 500 },
{ "product" : "socks", "store number" : 2, "quantity" : 10 },
{ "product" : "shirt", "store number" : 3, "quantity" : 10 }
];
var products = [
{ "name" : "broiler", "category" : "kitchen", "price" : 100, "cost" : 70 },
{ "name" : "toaster", "category" : "kitchen", "price" : 30, "cost" : 10 },
{ "name" : "blender", "category" : "kitchen", "price" : 50, "cost" : 25 },
{ "name" : "socks", "category" : "clothes", "price" : 5, "cost" : 2 },
{ "name" : "shirt", "category" : "clothes", "price" : 10, "cost" : 3 }
];
var stores = [
{ "store number" : 1, "state" : "CA" },
{ "store number" : 2, "state" : "CA" },
{ "store number" : 3, "state" : "MA" },
{ "store number" : 4, "state" : "MA" }
];
var nestedGroupingAndAggregate = stores.select().orderBy("state").groupBy("state")
( function(byState) {
var state = byState[0],
stateStores = byState[1];
byState = { };
return (
(
byState[state] =
products.select().orderBy("category").groupBy("category")
( function(byCategory) {
var category = byCategory[0],
categoryProducts = byCategory[1],
categorySales = sales.filter(function(sale) {
return stateStores.find(function(store) { return sale["store number"] === store["store number"]; }) &&
categoryProducts.find(function(product) { return sale.product === product.name; });
});
byCategory = { };
return (
(
byCategory[category] =
categorySales.select().orderBy("product").groupBy("product")
( function(byProduct) {
var soldProduct = byProduct[0],
soldQuantities = byProduct[1];
byProduct = { };
return (
(
byProduct[soldProduct] =
soldQuantities.reduce(function(sum, sale) { return sum += sale.quantity; }, 0)
),
byProduct
);
} ) // byProduct()
),
byCategory
);
} ) // byCategory()
),
byState
);
} ); // byState()
...与える:
[
{
"CA": [
{
"clothes": [
{
"socks": 510
}
]
},
{
"kitchen": [
{
"broiler": 20
},
{
"toaster": 150
}
]
}
]
},
{
"MA": [
{
"clothes": [
{
"shirt": 10
}
]
},
{
"kitchen": [
{
"blender": 250
},
{
"toaster": 50
}
]
}
]
}
]
JSONPath wrtの制限を克服することも役立ちます。このSOの質問(および他の質問)で提起された祖先軸に対するクエリ。
たとえば、ブランドIDを知っている食料品の割引を取得する方法
{
"prods": [
{
"info": {
"rate": 85
},
"grocery": [
{
"brand": "C",
"brand_id": "984"
},
{
"brand": "D",
"brand_id": "254"
}
],
"discount": "15"
},
{
"info": {
"rate": 100
},
"grocery": [
{
"brand": "A",
"brand_id": "983"
},
{
"brand": "B",
"brand_id": "253"
}
],
"discount": "20"
}
]
}
?
可能な解決策は次のとおりです。
var products = {
"prods": [
{
"info": {
"rate": 85
},
"grocery": [
{
"brand": "C",
"brand_id": "984"
},
{
"brand": "D",
"brand_id": "254"
}
],
"discount": "15"
},
{
"info": {
"rate": 100
},
"grocery": [
{
"brand": "A",
"brand_id": "983"
},
{
"brand": "B",
"brand_id": "253"
}
],
"discount": "20"
}
]
};
function GroceryItem(obj) {
return (typeof obj.brand === "string") && (typeof obj.brand_id === "string");
}
// last parameter set to "true", to grab all the "GroceryItem" instances
// at any depth:
var itemsAndDiscounts = [ products ].nodeset(GroceryItem, true).
map(
function(node) {
var item = node.value, // node.value: the current "GroceryItem" (aka "$.prods[*].grocery[*]")
discount = node.parent. // node.parent: the array of "GroceryItem" (aka "$.prods[*].grocery")
parent. // node.parent.parent: the product (aka "$.prods[*]")
discount; // node.parent.parent.discount: the product discount
// finally, project into an easy-to-filter form:
return { id: item.brand_id, discount: discount };
}
),
discountOfItem983;
discountOfItem983 = itemsAndDiscounts.
filter
(
function(mapped) {
return mapped.id === "983";
}
)
[0].discount;
console.log("Discount of #983: " + discountOfItem983);
...それは与える:
Discount of #983: 20
'HTH、
今があります!私は最近、まさにこの目的のために、ライブラリjson-transformsを作成しました:
https://github.com/ColinEberhardt/json-transforms
これは、JSPath、XPathでモデル化されたDSL、およびXSLTから直接発想を得た再帰的なパターンマッチングアプローチを組み合わせて使用します。
簡単な例を示します。次のJSONオブジェクトがあるとします。
const json = {
"automobiles": [
{ "maker": "Nissan", "model": "Teana", "year": 2011 },
{ "maker": "Honda", "model": "Jazz", "year": 2010 },
{ "maker": "Honda", "model": "Civic", "year": 2007 },
{ "maker": "Toyota", "model": "Yaris", "year": 2008 },
{ "maker": "Honda", "model": "Accord", "year": 2011 }
]
};
ここに変換があります:
const jsont = require('json-transforms');
const rules = [
jsont.pathRule(
'.automobiles{.maker === "Honda"}', d => ({
Honda: d.runner()
})
),
jsont.pathRule(
'.{.maker}', d => ({
model: d.match.model,
year: d.match.year
})
),
jsont.identity
];
const transformed = jsont.transform(json, rules);
次の出力:
{
"Honda": [
{ "model": "Jazz", "year": 2010 },
{ "model": "Civic", "year": 2007 },
{ "model": "Accord", "year": 2011 }
]
}
この変換は3つのルールで構成されています。1つ目は、Hondaによって製造された自動車に一致し、Honda
プロパティを持つオブジェクトを放出してから、再帰的に一致します。2番目のルールは、maker
プロパティを持つすべてのオブジェクトに一致し、model
およびyear
プロパティを出力します。最後は、再帰的に一致する恒等変換です。
古い質問に対する別の新しい回答として、私はDefiantJSを検討することをお勧めします。これは、XSLTのない同等、それは、JSONのためにある JSONのためのXSLT。ドキュメントの「テンプレーティング」セクションには、次の例が含まれています。
<!-- Defiant template -->
<script type="defiant/xsl-template">
<xsl:template name="books_template">
<xsl:for-each select="//movie">
<xsl:value-of select="title"/><br/>
</xsl:for-each>
</xsl:template>
</script>
<script type="text/javascript">
var data = {
"movie": [
{"title": "The Usual Suspects"},
{"title": "Pulp Fiction"},
{"title": "Independence Day"}
]
},
htm = Defiant.render('books_template', data);
console.log(htm);
// The Usual Suspects<br>
// Pulp Fiction<br>
// Independence Day<br>
私は、膨大な量のJavaScriptテンプレートエンジンとそのすべてのインラインHTMLテンプレート、さまざまなマークアップスタイルなどに本当にうんざりしていて、JSONデータ構造のXSLTフォーマットを可能にする小さなライブラリを構築することにしました。決してロケットサイエンスではありません。JSONがXMLに解析され、XSLTドキュメントでフォーマットされているだけです。それも高速で、ChromeのJavaScriptテンプレートエンジンほど高速ではありませんが、他のほとんどのブラウザでは、より大きなデータ構造のJSエンジンの代替と少なくとも同等の高速です。
XSLTを使用してJSONを変換することは非常に可能です。JSON2SAXデシリアライザーとSAX2JSONシリアライザーが必要です。
Javaのサンプルコード:http : //www.gerixsoft.com/blog/json/xslt4json
Yate(https://github.com/pasaran/yate)は、XSLTに基づいて特別に設計されており、JPath(JSに相当する自然なXPathに相当)を備え、JavaScriptにコンパイルされ、製品の使用にはかなりの歴史があります。これは実質的に文書化されていませんが、サンプルとテストを読むだけで十分です。
JSLTは、XSLTのJSONに相当します。これは、出力の固定部分をJSON構文で記述し、式を挿入してテンプレートに挿入する値を計算する変換言語です。
例:
{
"time": round(parse-time(.published, "yyyy-MM-dd'T'HH:mm:ssX") * 1000),
"device_manufacturer": .device.manufacturer,
"device_model": .device.model,
"language": .device.acceptLanguage
}
それはジャクソンの上にJavaで実装されています。
これの必要性があまり確かではなく、私にはツールの欠如が必要性の欠如を示唆しています。JSONはオブジェクトとして最もよく処理されます(とにかくJSで行われる方法)。通常、オブジェクト自体の言語を使用して変換を行います(JSONから作成されたJavaオブジェクトのJava、Perl、Python、Perl、c#、PHPなどでも同じ)オン)。通常の割り当て(または設定、取得)、ループなどを使用します。
つまり、XSLTは別の言語であり、XMLがオブジェクト表記ではないため、プログラミング言語のオブジェクトが正確に適合していない(階層型xmlモデルとオブジェクト/構造体の間のインピーダンス)ためです。
name
とaddress
、配列に入れて:[.name, .address]
Mr. Data Coverterを使用してJSONをXML に変換し、XSLTを使用して変換してから、同じようにJSONに戻してみませんか。
XSLTのマッチング式と再帰テンプレートの背後にある、よく知られた宣言的なパターンとともに、純粋なJavaScriptを利用するアプローチの実用的な落書き/概念実証については、 https://gist.github.com/brettz9/0e661b3093764f496e36をください。
(JSONについても同様のアプローチを取ることができます。)
デモは、Firefoxでテンプレートを表現するのに便利なように、JavaScript 1.8式クロージャーにも依存していることに注意してください(少なくともメソッドのES6ショートフォームが実装されるまで)。
免責事項:これは私自身のコードです。
私は昔、Jacksonベースのjson処理フレームワーク用のdomアダプターを書きました。nu.xomライブラリを使用します。結果のdomツリーは、java xpathおよびxslt機能で動作します。私は、かなり単純な実装の選択を行いました。たとえば、ルートノードは常に「ルート」と呼ばれ、配列は(htmlのように)liサブ要素を持つolノードに入り、その他はすべて、プリミティブ値または別のオブジェクトノードを持つサブノードです。
使用法:
JsonObject sampleJson = sampleJson();
org.w3c.dom.Document domNode = JsonXmlConverter.getW3cDocument(sampleJson, "root");
まだ与えられていない1つのアプローチは、パーサージェネレーターを使用して、JSONを解析してXML出力を生成するパーサーをXSLTで作成することです。
XML会議でよく言及される1つのオプションは、ReXパーサージェネレーター(http://www.bottlecaps.de/rex/)です。サイトにはまったく記載されていませんが、検索でレシピを入手できます。
JSONでXSLTを使用できる場合があります。XPath(3.1)、XSLT(3.0)およびXQuery(3.1)のバージョン3は、JSONを何らかの方法でサポートしています。これは商用バージョンのSaxonで利用できるようで、いつかHEバージョンに含まれる可能性があります。 https://www.saxonica.com/html/documentation/functions/fn/parse-json.html
-
私が代替ソリューションに期待すること:
JSONを入力して、一致するデータのセットをフェッチし、JSONまたはTEXTを出力できるようにしたいと思います。
任意のプロパティにアクセスして値を評価する
条件付きロジックのサポート
変換スクリプトをツールの外部、テキストベース、できれば一般的に使用される言語にしたいと思います。
潜在的な代替ですか?
SQLが適切な代替案になるのではないかと思います。 https://docs.microsoft.com/en-us/sql/relational-databases/json/json-data-sql-server
代替ツールでJSONとXMLを処理できると便利です https://docs.microsoft.com/en-us/sql/relational-databases/xml/openxml-sql-server
私はまだ使用しているXSLTスクリプトをSQLに変換することを試みていないか、このオプションを完全に評価していませんが、もっと早く調査したいと思っています。これまでのいくつかの考え。