编辑虽然从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。
答案 0 :(得分:2)
你在错误的地方使用谓词。
你的表达,
/descendant::my:section1/my:group/pc:Person/pc:DisplayName[1]
返回一组pc:DisplayName
个元素,这些元素是相应父元素中的第一个元素(pc:Person
元素),因此您获得了DOMAIN\John.Green
和DOMAIN\john.smith
基本上每个DisplayName
Person
中group
的 section1
>
你想要的是每个{{1}的每个DisplayName
中 第一个Person
的group
转换为以下XPath表达式的:
section1