我需要将在xml中格式化的一个文档转换为JSON,反之亦然。
我相信这是一个常见的要求,也许还有一个图书馆可以做到这一点。
知道吗?
答案 0 :(得分:1)
不是C#,而是纯XSLT 2.0实现,它将JSON对象转换为XML文档:
查看f:json-document()
中的FXSL 2.x library。
使用此函数非常容易合并JSon并将其用作... XML。
例如,可以编写以下XPath表达式:
f:json-document($vstrParam)/Students/*[sex = 'Female']
和让Students
的所有孩子都拥有sex = 'Female'
以下是完整示例:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:f="http://fxsl.sf.net/"
exclude-result-prefixes="f xs"
>
<xsl:import href="../f/func-json-document.xsl"/>
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:variable name="vstrParam" as="xs:string">
{
"teacher":{
"name":
"Mr Borat",
"age":
"35",
"Nationality":
"Kazakhstan"
},
"Class":{
"Semester":
"Summer",
"Room":
null,
"Subject":
"Politics",
"Notes":
"We're happy, you happy?"
},
"Students":
{
"Smith":
{"First Name":"Mary","sex":"Female"},
"Brown":
{"First Name":"John","sex":"Male"},
"Jackson":
{"First Name":"Jackie","sex":"Female"}
}
,
"Grades":
{
"Test":
[
{"grade":"A","points":68,"grade":"B","points":25,"grade":"C","points":15},
{"grade":"C","points":2, "grade":"B","points":29, "grade":"A","points":55},
{"grade":"C","points":2, "grade":"A","points":72, "grade":"A","points":65}
]
}
}
</xsl:variable>
<xsl:template match="/">
<xsl:sequence select=
"f:json-document($vstrParam)/Students/*[sex = 'Female']"/>
</xsl:template>
</xsl:stylesheet>
当对任何XML文档应用上述转换(忽略)时,会生成正确的结果:
<Smith>
<First_Name>Mary</First_Name>
<sex>Female</sex>
</Smith>
<Jackson>
<First_Name>Jackie</First_Name>
<sex>Female</sex>
</Jackson>
答案 1 :(得分:0)
结帐Json.NET。这是一个很容易进入的好图书馆。
答案 2 :(得分:0)
我不确定从json到xml,但是我们使用这个xml到json xsl模板在基于XML的CMS中发挥了很大作用,非常方便为ajax应用程序重用现有的XML结构。