SharePoint自动化系列——Set MMS field value using PowerShell.

 

本章将总结一下设置SharePoint list中item的Managed Metadata field value的方法。web

如下函数是我封装好的能够直接用来获取相应Managed Metadata类型field的terms value:api

Add-PSSnapin Microsoft.SharePoint.PowerShell
function GetFieldTerms
{
  param($siteUrl,$listTitle,$fieldName)
  $site = Get-SPSite $siteUrl
  $web = $site.rootweb
  $List = $web.lists[$listTitle]
  $MMSField = $List.Fields[$fieldName]
  $MMSFieldtsId = $MMSField.TermSetId
  $MMSFieldtermStoreId = $MMSField.SspId
  $MMSFieldtsession = Get-SPTaxonomySession -Site $site
  $MMSFieldtstore = $MMSFieldtsession.TermStores[$MMSFieldtermStoreId]
  $MMSFieldtset = $MMSFieldtstore.GetTermSet($MMSFieldtsId)
  $terms = $MMSFieldtset.terms
  $terms
}数组

该函数的返回值为$terms,因此在使用的过程当中能够将该结果存储到你所须要保存到的变量中,使用方法以下(引号中是须要你去填写的数据):session

$terms = GetFieldTerms -siteUrl "" -listTitle "" -fieldName ""

在PowerShell中运行的结果以下,咱们能够看到,相应的terms都已经保存到咱们的变量$terms中:ide

接下来,就是将获取到的terms的值赋予到SharePoint list item相应field的过程(与正常的赋值过程不一样):函数

#正常field的赋值方法:
$Item["fieldName"] = $value
#MMS类型field的赋值方法($index为$terms数组变量中相应位置的索引): $list.fields["fieldName"].SetFieldValue($Item,terms[$index])

之后陆续我还会总结一些其余类型field的赋值方法,欢迎你们提问与交流。blog

相关文章
相关标签/搜索