用于在重复父节点中选择元素的第一个实例的XPath表达式

时间:2012-09-25 14:24:18

标签: xml xpath infopath

编辑虽然从XPath的角度来看,这个问题的答案(谢谢Tom!)在技术上是正确的,但MS InfoPath与人物选择器的搭配并不好。请注意,这不允许您清除人员选择器并重新分配第一个选定的人员。 InfoPath仅在重新验证人员选择器后清除已存在的XML结构。这意味着将应用程序的焦点从拾取器上移开然后再切换回来。由于MS InfoPath中的技术限制,我的最终目标似乎无法实现。在那,我希望这证明对那里的其他新手有用!

问题:我需要选择父节点中重复的节点或元素的第一个实例。  (我的术语可能不正确)。尝试在stackoverflow上调整其他帖子中的表达式无济于事。

基本情况:使用MS InfoPath中的人员/组选择器。如果有人在选择器字段中选择了多个用户,我想将其重置为第一个选择的用户。麻烦的是,表单上有多个使用类似XML结构的选择器,因此我的XPath无法运行...

InfoPath将处理表达式并使用规则来检查选择器中是否存在多个用户。

这是我的示例XML,然后是我的失败表达式:

<?xml version="1.0" encoding="UTF-8"?><?mso-infoPathSolution solutionVersion="1.0.0.24" productVersion="14.0.0" PIVersion="1.0.0.0" href="file:///C:\Documents%20and%20Settings\Chris\Local%20Settings\Application%20Data\Microsoft\InfoPath\Designer3\35e8a7eff4a841a9\manifest.xsf" ?><?mso-application progid="InfoPath.Document" versionProgid="InfoPath.Document.2"?><my:myFields xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:pc="http://schemas.microsoft.com/office/infopath/2007/PartnerControls" xmlns:ma="http://schemas.microsoft.com/office/2009/metadata/properties/metaAttributes" xmlns:d="http://schemas.microsoft.com/office/infopath/2009/WSSList/dataFields" xmlns:q="http://schemas.microsoft.com/office/infopath/2009/WSSList/queryFields" xmlns:dfs="http://schemas.microsoft.com/office/infopath/2003/dataFormSolution" xmlns:dms="http://schemas.microsoft.com/office/2009/documentManagement/types" xmlns:tns="http://microsoft.com/webservices/SharePointPortalServer/UserProfileService" xmlns:s1="http://microsoft.com/wsdl/types/" xmlns:my="http://schemas.microsoft.com/office/infopath/2003/myXSD/2012-09-06T15:09:43" xmlns:xd="http://schemas.microsoft.com/office/infopath/2003" xml:lang="en-us">
<my:section1>
    <my:group>
        <pc:Person xmlns:pc="http://schemas.microsoft.com/office/infopath/2007/PartnerControls">
            <pc:DisplayName>Green, John</pc:DisplayName>
            <pc:AccountId>DOMAIN\John.Green</pc:AccountId>
            <pc:AccountType>User</pc:AccountType>
        </pc:Person><pc:Person xmlns:pc="http://schemas.microsoft.com/office/infopath/2007/PartnerControls">
            <pc:DisplayName>Smith, John</pc:DisplayName>
            <pc:AccountId>DOMAIN\john.smith</pc:AccountId>
            <pc:AccountType>User</pc:AccountType></pc:Person>
    </my:group>
</my:section1>
<my:section2>
    <my:group>
        <pc:Person xmlns:pc="http://schemas.microsoft.com/office/infopath/2007/PartnerControls">
            <pc:DisplayName>Public, John</pc:DisplayName>
            <pc:AccountId>DOMAIN\John.Q.Public</pc:AccountId>
            <pc:AccountType>User</pc:AccountType>
        </pc:Person><pc:Person xmlns:pc="http://schemas.microsoft.com/office/infopath/2007/PartnerControls">
            <pc:DisplayName>Doe, John</pc:DisplayName>
            <pc:AccountId>DOMAIN\John.Doe</pc:AccountId>
            <pc:AccountType>User</pc:AccountType></pc:Person>
    </my:group>
</my:section2>
</my:myFields>

以下表达式返回两者 DOMAIN \ John.Green和DOMAIN \ John.Smith ......

/descendant::my:section1/my:group/pc:Person/pc:DisplayName[1]

关闭,但没有雪茄。

我需要两个单独的表达方式;一个选择DOMAIN \ John.Green,一个选择DOMAIN \ John.Q.Public。

1 个答案:

答案 0 :(得分:2)

你在错误的地方使用谓词。

你的表达,

/descendant::my:section1/my:group/pc:Person/pc:DisplayName[1]

返回一组pc:DisplayName个元素,这些元素是相应父元素中的第一个元素(pc:Person元素),因此您获得了DOMAIN\John.GreenDOMAIN\john.smith

基本上每个DisplayName

的每个Persongroup
section1 >

你想要的是每个{{1}的每个DisplayName 第一个Person group转换为以下XPath表达式的section1