0

我有一个看起来像这样的 pmd.xml 文件:

<file name="file1">
  <violation rule="rulename1" priority="1">
  </violation>
  <violation rule="rulename2" priority="2">
  </violation>
</file>
<file name="file2">
  <violation rule="rulename2" priority="2">
  </violation>
  <violation rule="rulename3" priority="1">
  </violation>
</file>

我正在使用 xslt 文件将其转换为另一个 xml 文件。

我现在尝试做的是:对于每个优先级 = 1 的违规,计算整个 xml 中具有相同名称的违规数量。稍后与Prio = 2相同。

这样我就可以列出所有违规行为以及它们在文档中出现的频率,大致如下:

prio1:
rulename1, 1
rulename3, 1
prio2:
rulename2, 2

我找不到合适的 XPath 表达式来计算具有相同名称的违规行为...

<xsl:for-each select="//violation[@priority = 1]">
<xsl:value-of select="count(???)"/>

有人有帮助的想法吗?

提前致谢!

4

1 回答 1

1

假设 XSLT 1.0 您可以使用键进行分组:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:output method="text"/>

<xsl:key name="k1" match="violation" use="@priority"/>
<xsl:key name="k2" match="violation" use="concat(@priority, '|', @rule)"/>

<xsl:template match="/">
  <xsl:apply-templates select="//violation[generate-id() = generate-id(key('k1', @priority)[1])]"/>
</xsl:template>

<xsl:template match="violation">
  <xsl:value-of select="concat('prio', @priority, ':&#10;')"/>
  <xsl:apply-templates select="key('k1', @priority)[generate-id() = generate-id(key('k2', concat(@priority, '|', @rule))[1])]" mode="rule"/>
</xsl:template>

<xsl:template match="violation" mode="rule">
  <xsl:value-of select="concat(@rule, ', ', count(key('k2', concat(@priority, '|', @rule))), '&#10;')"/>
</xsl:template>

</xsl:stylesheet>

变换

<files>
<file name="file1">
  <violation rule="rulename1" priority="1">
  </violation>
  <violation rule="rulename2" priority="2">
  </violation>
</file>
<file name="file2">
  <violation rule="rulename2" priority="2">
  </violation>
  <violation rule="rulename3" priority="1">
  </violation>
</file>
</files>

进入

prio1:
rulename1, 1
rulename3, 1
prio2:
rulename2, 2
于 2013-10-17T16:25:08.407 回答