- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想创建一个可以转换 XML 的 XSLT,以便在输出 XML(来自 XSLT)中排除所有未在 XSD 中定义的元素和属性。
假设您有这个 XSD。
<xs:element name="parent">
<xs:complexType>
<xs:sequence>
<xs:element name="keptElement1" />
<xs:element name="keptElement2" />
</xs:sequence>
<xs:attribute name="keptAttribute1" />
<xs:attribute name="keptAttribute2" />
</complexType>
</xsd:element>
你有这个输入 XML
<parent keptAttribute1="kept"
keptAttribute2="kept"
notKeptAttribute3="not kept"
notKeptAttribute4="not kept">
<notKeptElement0>not kept</notKeptElement0>
<keptElement1>kept</keptElement1>
<keptElement2>kept</keptElement2>
<notKeptElement3>not kept</notKeptElement3>
</parent>
然后我希望输出的 Xml 看起来像这样。
<parent keptAttribute1="kept"
keptAttribute2="kept">
<keptElement1>kept</keptElement1>
<keptElement2>kept</keptElement2>
</parent>
我可以通过指定元素来做到这一点,但这大约是我的 xslt 技能所能达到的范围。我通常对所有元素和所有属性执行此操作时遇到问题。
最佳答案
您在这里面临两个挑战:(1) 识别模式中声明的元素名称和属性集,以及本地声明的适当上下文信息,以及 (2) 编写 XSLT 以保留与这些名称或名称匹配的元素和属性-和上下文。
还有第三个问题,即明确说明“XSD 架构中定义(或未定义)的元素和属性”的含义。出于讨论的目的,我假设您指的是可以绑定(bind)到模式中的元素或属性声明的元素和属性,在验证情节 (a) Root 于输入文档树中的任意点,以及 (b) 以 a 开头顶级元素声明或属性声明。这个假设意味着几件事。 (a) 本地元素声明只会匹配上下文中的内容——在您的示例中,keptElement1
和 keptElement2
只有当它们是 parent
的 child 时才会保留,否则不会。 (b) 无法保证输入中的元素实际上会绑定(bind)到有问题的元素声明:如果它们的祖先之一在本地无效,那么在 XSD 1.0 和 1.1 中事情都会很快变得复杂。 (c) 我们不允许从命名类型定义开始验证;我们可以,但听起来好像这不是您感兴趣的内容。(d) 我们不允许从本地元素或属性声明开始验证。
有了这些明确的假设,我们就可以转向您的问题了。
第一个任务要求您列出 (a) 架构中具有顶级声明的所有元素和属性,以及 (b) 从它们可以访问的所有元素和属性。对于顶级声明,我们只需要记录对象(元素或属性)的种类和展开后的名称即可。对于本地对象,我们需要对象的种类和顶级元素声明的完整路径。对于您的示例架构,列表 (a) 包括
(我使用的惯例是在大括号中使用 namespace 名称编写扩展名称;有些人称此为 James Clark 的 Clark 表示法。)
列表(b)包括
在更复杂的模式中,在生成此列表的过程中会有一定数量的簿记。
您的第二个任务是编写一个 XSLT 样式表,将元素和属性保留在列表中并删除其余部分。 (我在这里假设当你放下一个元素时,你也会放下它的所有内容;你的问题谈论的是元素,而不是标签。)
对于列表中的每个元素,使用列表中给定的上下文编写适当的身份转换:
<xsl:template match="parent">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
可以为每个元素写一个单独的模板,也可以将几个元素写到匹配模式中:
<xsl:template match="parent
| parent/keptElement1
| parent/keptElement2">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
对于列表中的每个属性,执行相同的操作:
<xsl:template match="parent/@keptAttribute1">
<xsl:copy/>
</xsl:template>
覆盖元素和属性的默认模板,以抑制所有其他元素和属性:
<xsl:template match="*|@*"/>
[或者,如 DrMacro 所建议的,您可以在 XSLT 中编写一个函数或命名模板来查询您在任务 1 中生成的列表,而不是将其写出到具有显式匹配模式的重复模板中。根据您的背景,您可能会发现这种方法更容易或更难理解样式表的作用。]
关于xml - 使用 XSLT 根据 XSD 转换 XML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14833486/
我有一个 XSLT 样式表,如下所示: 我想使用第二个 XSLT 样式表来转换此样式表,以删除与 XQHead
我们有一个大型 xslt,可以呈现整个商店区域,包括产品、制造商,并根据价格和类别进行过滤。我使用 sitecore 作为 CMS,但遇到缓存问题。我有大约 9000 个项目,有些页面需要长达 20
我想根据条件的结果应用具有不同参数的模板。像这样: Attribute no. 1
我有一些看起来像这样的 XML Foo Details Bar Details Baz Details Foo Blah Bar BlahBlah Baz BlahBlahBl
我试图从这种输入出发: a b c d e f g ... 使用 XSLT 的 HTML 输出: one two a e b f
我想知道如何在 xslt 中找到特定节点的第一个子节点名称。 我有一个 xml: some text 我可以使用 body/
是否可以在 XSLT 中获取上个月的最后一天?我找到了这个函数:http://www.xsltfunctions.com/xsl/functx_last-day-of-month.html但我不确定如
具有特定节点的匹配元素存在问题。 xml: description of profile PhoneKeyPad S
我将一堆键值对作为参数传递给 XSL(日期 ->“1 月 20 日”,作者 ->“Dominic Rodger”,...)。 我正在解析的一些 XML 中引用了这些 - XML 如下所示: 目前,除
我找不到这个问题的确切答案,所以我希望有人能在这里帮助我。 我有一个字符串,我想在最后一个 '.' 之后获取子字符串。我正在使用 xslt 1.0。 这是怎么做的?这是我的代码。
我在尝试找出 xslt 上的 var 范围时遇到问题。我实际上想要做的是忽略具有重复“旅游代码”的“旅行”标签。 示例 XML: X1 Budapest X1 Budapest X
我有一些数据在 xslt 的 for-each 循环中输出。我对列表进行了分页,但没有对排序选择器进行分页。 用户应该能够对 2 个值(创建的数据和每个项目的数字字段)进行排序。默认的排序方法是创建日
我有一个奇怪的要求。 我在 xslt 中有一个包含月份的变量,带有它们的 id (1-12) 问题是我需要全部显示它们,但从一月(1)以外的月份开始。 目前我有以下 JAN
如何在 xslt 转换中模块化一组重复的输出?例如,我有如下内容(伪代码)。 并
我得到一个像这样的字符串。 13091711111100222222003333330044444400 字符串的模式是这样的 13 - 09 - 17 - 11111 - 100 - 22222 -
我是 XSLT 的新手,有一个一般性问题。为了区分具有不同属性的两个元素,最好(也是为了性能)使用 和 而不是 在一个模板中。据我所知,这就是 XSLT 中应该“思考”的方式。但在我看来,这有一个缺点
如何从“19650512-0065”到“196505120065”这样的字符串中删除连字符 使用这个模板:传递 theID =
是否有任何功能可以在左侧填充零? 我正在尝试做的要求是: 我们不知道即将到来的输入字符串长度。 如果小于 20,我们必须在左侧填充零。 如果输入字符串长度为 10,那么我们必须在左侧填充 10 个零。
身份模板如下所示: 是否选择多于 ,或者身份模板可能是这样的? 当我执行以下操作时,究竟选择了什么? 最佳答案
我正在尝试使用 XML 信息和 XSLT 模板创建超链接。这是 XML 源代码。 Among individual stocks, the top percentage gainers in the
我是一名优秀的程序员,十分优秀!