我很难使用下面的用例。
以下是XML:
<NodeA>
<NodeB>
<Application id="I-555" name="Text1" XorY="Y" />
<Application id="I-666" name="Text2" XorY="X" />
<Application id="I-777" name="Text3" XorY="Y" />
<Application id="I-888" name="Text4" XorY="X" />
</NodeB>
</NodeA>
<NodeD>
<NodeE>
<Process id="111" name="Text1" />
<Process id="222" name="Text2" />
<Process id="333" name="Text2" />
<Process id="444" name="Text2" />
</NodeE>
</NodeD>
<Links_between_Process_and_Application>
<Link_Process_App app_id="I-555" process_id="111" />
<Link_Process_App app_id="I-666" process_id="222" />
<Link_Process_App app_id="I-777" process_id="333" />
<Link_Process_App app_id="I-888" process_id="444" />
</Links_between_Process_and_Application>
我想要实现的是基于节点
棘手的部分是(至少对我来说)根据
XorY
(伪代码)中的属性值创建两个不同的链接/节点:
通过
我已经为转换编写了两个XSLT并生成了这两个链接(没有检查属性XorY),因为我真的不知道如何从不同的用例中检查属性的值:
<?xml version='1.0' ?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="/">
<ImportSchemaBase>
<xsl:for-each select="Links_between_Process_and_Application/Link_Process_App">
<Link_Process_Application>
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</Link_Process_Application>
</xsl:for-each>
</ImportSchemaBase>
</xsl:template>
</xsl:stylesheet>
和:
<?xml version='1.0' ?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="/">
<ImportSchemaBase>
<xsl:for-each select="Links_between_Process_and_Application/Link_Process_App">
<Link_Process_IDP>
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</Link_Process_IDP>
</xsl:for-each>
</ImportSchemaBase>
</xsl:template>
</xsl:stylesheet>
结果应该是:
创建Link_Process_IDP因为对于"app_id=I-555"XorY是Y
<Link_Process_IDP>
<SourceKey>111</SourceKey>
<TargetKey>I-555</TargetKey>
</Link_Process_IDP>
创建链接\u进程\u应用程序,因为“app\u id=I-666”的XorY是X
<Link_Process_Application>
<SourceKey>222</SourceKey>
<TargetKey>I-666</TargetKey>
</Link_Process_Application>
创建链接\u进程\u IDP,因为“应用程序\u id=I-777”的XorY为Y
<Link_Process_IDP>
<SourceKey>333</SourceKey>
<TargetKey>I-777</TargetKey>
</Link_Process_IDP>
创建链接\u进程\u应用程序,因为“app\u id=I-888”的XorY是X
<Link_Process_Application>
<SourceKey>444</SourceKey>
<TargetKey>I-888</TargetKey>
</Link_Process_Application>
非常感谢,很抱歉描述得太长了!
我会这样做:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:key name="app" match="Application" use="@id"/>
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<xsl:apply-templates select="//Link_Process_App"/>
</xsl:template>
<xsl:template match="Link_Process_App[key('app', @app_id)/@XorY = 'X']">
<Link_Process_Application>
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</Link_Process_Application>
</xsl:template>
<xsl:template match="Link_Process_App[key('app', @app_id)/@XorY = 'Y']">
<Link_Process_IDP>
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</Link_Process_IDP>
</xsl:template>
</xsl:stylesheet>
https://xsltfiddle.liberty-development.net/bEJbVra/1
您的输入不是XML—它缺少一个根元素(预期的输出也是如此)。
给定格式良好的XML输入,使用一个键即可轻松完成任务:
XML
<root>
<NodeA>
<NodeB>
<Application id="I-555" name="Text1" XorY="Y" />
<Application id="I-666" name="Text2" XorY="X" />
<Application id="I-777" name="Text3" XorY="Y" />
<Application id="I-888" name="Text4" XorY="X" />
</NodeB>
</NodeA>
<NodeD>
<NodeE>
<Process id="111" name="Text1" />
<Process id="222" name="Text2" />
<Process id="333" name="Text2" />
<Process id="444" name="Text2" />
</NodeE>
</NodeD>
<Links_between_Process_and_Application>
<Link_Process_App app_id="I-555" process_id="111" />
<Link_Process_App app_id="I-666" process_id="222" />
<Link_Process_App app_id="I-777" process_id="333" />
<Link_Process_App app_id="I-888" process_id="444" />
</Links_between_Process_and_Application>
</root>
XSLT1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:key name="app" match="Application" use="@id" />
<xsl:template match="/root">
<output>
<xsl:for-each select="Links_between_Process_and_Application/Link_Process_App">
<xsl:variable name="xory" select="key('app', @app_id)/@XorY" />
<xsl:variable name="name">
<xsl:choose>
<xsl:when test="$xory = 'X'">Link_Process_Application</xsl:when>
<xsl:when test="$xory = 'Y'">Link_Process_IDP</xsl:when>
<xsl:otherwise>SomethingElse</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:element name="{$name}">
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</xsl:element>
</xsl:for-each>
</output>
</xsl:template>
</xsl:stylesheet>
结果
<?xml version="1.0" encoding="UTF-8"?>
<output>
<Link_Process_IDP>
<SourceKey>111</SourceKey>
<TargetKey>I-555</TargetKey>
</Link_Process_IDP>
<Link_Process_Application>
<SourceKey>222</SourceKey>
<TargetKey>I-666</TargetKey>
</Link_Process_Application>
<Link_Process_IDP>
<SourceKey>333</SourceKey>
<TargetKey>I-777</TargetKey>
</Link_Process_IDP>
<Link_Process_Application>
<SourceKey>444</SourceKey>
<TargetKey>I-888</TargetKey>
</Link_Process_Application>
</output>
请注意,如果X
和Y
是互斥的,您可以将其进一步缩短为:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:key name="app" match="Application" use="@id" />
<xsl:template match="/root">
<output>
<xsl:for-each select="Links_between_Process_and_Application/Link_Process_App">
<xsl:variable name="name">
<xsl:choose>
<xsl:when test="key('app', @app_id)/@XorY = 'X'">Link_Process_Application</xsl:when>
<xsl:otherwise>Link_Process_IDP</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:element name="{$name}">
<SourceKey>
<xsl:value-of select="@process_id"/>
</SourceKey>
<TargetKey>
<xsl:value-of select="@app_id"/>
</TargetKey>
</xsl:element>
</xsl:for-each>
</output>
</xsl:template>
</xsl:stylesheet>
对于下面的XML,我正在尝试根据属性和节点值提取节点。 基于属性class=pass和h1包含('objectives'),我试图提取以下输出。 “目标”是节点值字符串“1任务目标”的一部分 1任务目标1目标2 下面是我正在尝试的XPath表达式。然而,这并没有产生任何输出。你能指出我做错了什么吗? 谢谢
如何能够基于另一个同级节点的属性选择节点属性?我想要实现的是从所有节点中提取链接(href值),这些节点后跟具有属性class=“body table news loss”的节点跨度,即选择器应该返回https://finance.yahoo.com/news/inspiremd-announces-planned-recapitalization-120000752.html在下面的示例中。我试
SyntaxError:无效输入“h”:预期为“I/I”(第10行,第28列(偏移量:346))“merge(p:primaryconsumer),其中p.name=svc.name” 我100%确信这些名称是唯一的,并且将与现有节点集中的唯一使用者名称相匹配(有待观察)。 当唯一节点属性匹配时,如何将现有属性添加到新数据中?(我希望获得唯一的ID,但我必须能够在匹配上执行新数据的更新)
我的目标是在StatusDate为1900-01-01T00:00:00时使用此XSLT样式表删除整个LoanSecondaryStatus节点,但在其他日期时保留该节点。 我有以下XML: 这是我用来尝试删除Loan二级状态节点的XSLT:
我正在创建一个简单的社交图,用户可以在其中创建一个帖子,标记它,并对它进行评论。我用py2neo做模型。该模型具有和作为节点。用户在上、或。在我的例子中,单个用户可以在单个上创建多个或(就像其他任何社交网络一样)。根据我的模型,这需要多个或关系,但具有不同的属性。模型是这样建立的: 我运行以下操作来构建图形: 我希望有两个关系,如下所示: 但我看到事实并非如此: 那么,我的问题是双重的。(1)可以