0

我正在研究 SP 2010 中的数据视图 Web 部件,以汇总来自子站点的一些信息。这些站点包含项目任务列表,这些列表具有分配给用户的任务。客户希望看到一个汇总,该汇总将根据用户是否分配了任务列出项目。由于一个项目可以有多个任务,因此一个项目可能会显示在汇总中的多个用户下,具体取决于哪些任务分配给了哪些用户。

长话短说,我需要一种方法来为每个用户选择不同项目的数量

xml结构是这样的:

<Rows>
  <Row Project="Project 1" TaskID="1" AssignedTo="Worker A" />
  <Row Project="Project 1" TaskID="2" AssignedTo="Worker B" />
</Rows>

由此,我希望项目计数如下:
工人 A:1
工人 B:1

我正在尝试以下公式:

count($nodeset[not(@Project=preceding-sibling::Row/@Project) and @AssignedTo = current()/@AssignedTo])

这将为工人 A 返回 1 个项目的计数,但为工人 B 返回 0,因为已经为工人 A 计算了项目 1。

我对 xslt 了解不多,但据我了解,使用 current() 并不是最资源友好的方法。我试图做 muenchian 分组,但我无法让它工作。不过愿意再试一次。任何建议都会有所帮助,因为我再次对 xslt 感到厌恶。

4

1 回答 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:strip-space elements="*"/>

 <xsl:key name="kWorker" match="@AssignedTo" use="."/>
 <xsl:key name="kProjByWorker" match="@Project" use="../@AssignedTo"/>
 <xsl:key name="kProjWorker" match="@Project" use="concat(.,'+',../@AssignedTo)"/>

 <xsl:template match="/*">
  <xsl:apply-templates select=
  "//@AssignedTo
     [generate-id()
     =
      generate-id(key('kWorker',.)[1])
      ]"/>
 </xsl:template>

 <xsl:template match="@AssignedTo">
  <xsl:value-of select="concat('&#xA;',.,': ')"/>

  <xsl:value-of select=
   "count(
     key('kProjByWorker', .)
       [generate-id()
       =
        generate-id(key('kProjWorker', concat(.,'+',current()))[1])]
     )"/>
 </xsl:template>
</xsl:stylesheet>

当应用于以下 XML 文档(所提供文档的更具挑战性的版本)时:

<Rows>
  <Row Project="Project 1" TaskID="1" AssignedTo="Worker A" />
  <Row Project="Project 1" TaskID="2" AssignedTo="Worker B" />
  <Row Project="Project 1" TaskID="2" AssignedTo="Worker A" />
  <Row Project="Project 2" TaskID="1" AssignedTo="Worker A" />
</Rows>

产生想要的正确结果

Worker A: 2
Worker B: 1

说明

使用Muenchian 分组方法两次:查找所有不同的工人,然后找到分配给该工人的不同项目。

于 2012-08-22T13:13:29.517 回答