Добавить столбец в список SharePoint Online 2013 с помощью Powershell v3
Кто-нибудь может сказать мне, как это сделать? Кажется, ни один из найденных примеров не работает.
Мой сайт https://blah.sharepoint.com/technology а мой список называется "pfa". Я хочу добавить несколько текстовых столбцов.
У меня действительно есть связь с SharePoint Online через мой Powershell, так как мне удалось получить некоторые результаты от различных команд.
Благодарю.
2 ответа
Как подготовить поле в SharePoint Online через CSOM в PowerShell
CSOM API поставляется с:
- FieldCollection.Add метод - добавляет поле в коллекцию полей
- Метод FieldCollection.AddFieldAsXml - создает поле на основе указанной схемы, логического значения и параметров поля
добавить список или колонку сайта.
Пример ниже демонстрирует, как добавить GeoLocation
поле в Contacts
Список:
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client")
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client.Runtime")
function Provision-Field([Microsoft.SharePoint.Client.ClientContext]$Context,[string]$ListTitle,[string]$FieldSchema)
{
$list = $Context.Web.Lists.GetByTitle($ListTitle)
$List.Fields.AddFieldAsXml($FieldSchema,$true,[Microsoft.SharePoint.Client.AddFieldOptions]::AddFieldToDefaultView)
$Context.Load($List)
$Context.ExecuteQuery()
}
$UserName = "username@contoso.onmicrosoft.com"
$Password = Read-Host -Prompt "Please enter your password" -AsSecureString
$URL = "https://contoso.sharepoint.com/"
$Context = New-Object Microsoft.SharePoint.Client.ClientContext($URL)
$Credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($UserName,$Password)
$Context.Credentials = $Credentials
Provision-Field $Context "Contacts" "<Field Type='Geolocation' DisplayName='Location'/>"
Как подготовить поле в SharePoint Online через REST в PowerShell
Endpoints:
http://<site url>/_api/web/fields('<field id>')
http://<site url>/_api/web/lists(guid'<list id>')/fields('<field id>')
В статье Использование API REST SharePoint 2013 из PowerShell описывается, как отправлять HTTPS-запросы в веб-службы SharePoint REST.
Используя функцию Invoke-RestSPO из статьи, в следующем примере показано, как добавить поле "Примечание" в список с помощью REST API в PowerShell:
Function Add-SPOField(){
Param(
[Parameter(Mandatory=$True)]
[String]$WebUrl,
[Parameter(Mandatory=$True)]
[String]$UserName,
[Parameter(Mandatory=$False)]
[String]$Password,
[Parameter(Mandatory=$True)]
[String]$ListTitle,
[Parameter(Mandatory=$True)]
[String]$FieldTitle,
[Parameter(Mandatory=$True)]
[System.Int32]$FieldType
)
$fieldMetadata = @{
__metadata = @{'type' = 'SP.Field' };
Title = $FieldTitle;
FieldTypeKind = $FieldType;
} | ConvertTo-Json
$Url = $WebUrl + "_api/web/Lists/GetByTitle('" + $ListTitle + "')/fields"
$contextInfo = Get-SPOContextInfo $WebUrl $UserName $Password
Invoke-RestSPO $Url Post $UserName $Password $fieldMetadata $contextInfo.GetContextWebInformation.FormDigestValue
}
. ".\Invoke-RestSPO.ps1" #InInvoke-RestSPO function
$UserName = "username@contoso.onmicrosoft.com"
$Password = Read-Host -Prompt "Please enter your password"
$WebUrl = "https://contoso.sharepoint.com/"
Add-SPOField -WebUrl $WebUrl -UserName $UserName -Password $Password -ListTitle "Documents" -FieldTitle "Comments" -FieldType 3
Рекомендации
Вот кто-то, кто создал список с CSOM через PowerShell с SharePoint Oneline http://www.hartsteve.com/2013/06/sharepoint-online-powershell/
PowerShell для SharePoint онлайн ограничен только некоторыми базовыми задачами администратора. Когда вы использовали CSOM в PowerShell, вы можете сделать гораздо больше.