質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SharePoint

SharePointは、マイクロソフトにより開発された、ソフトウェア開発のドキュメント管理やコラボレーションを行うプラットフォームの総称です

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

0回答

10039閲覧

SharepointOnline powershellでリストアイテムを追加する

ruikahiromi

総合スコア6

SharePoint

SharePointは、マイクロソフトにより開発された、ソフトウェア開発のドキュメント管理やコラボレーションを行うプラットフォームの総称です

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

0クリップ

投稿2019/09/02 02:55

前提・実現したいこと

初心者です。初投稿です。

<最終的にやりたいこと>
SharePointOnlineのカスタムリストに
powershellでアイテムを追加したいです。

発生している問題・エラーメッセージ

"0" 個の引数を指定して "ExecuteQuery" を呼び出し中に例外が発生しました: "列 '社員名' が存在しません。他のユーザーが削除した可能性があります。

上記がでるため、

$colItemsの中身を見てみたいと思いますが、
Microsoft.SharePoint.Client.ListItem
とリスト名が表示されてしまいます。

$newItem["○○"]を内部のプロパティ値を知る為にはどの様にするべきでしょうか。
※表示名ではないようです・・・。

ブラウザのsharepointonlineで表示名ではなく、内部プロパティ名をGUIにて知る方法があれば
そちらの方法でも構いません。

該当のソースコード

CSOM ライブラリを読み込む

[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client") | Out-Null
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client.Runtime") | Out-Null

コンテキスト作成や初期処理

$siteUrl = "https://<ひみつ>.sharepoint.com/sites/sitetop"
$ctx = New-Object Microsoft.SharePoint.Client.ClientContext($siteUrl)
$accountName = "ひみつ@ひみつ.onmicrosoft.com"

$password = ConvertTo-SecureString -AsPlainText -Force "ひみつ"

$credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($accountName, $password)
$ctx.Credentials = $credentials

リストの取得

$list = $ctx.Web.Lists.GetByTitle("TopList")

リストアイテム取得

$camlQuery = [Microsoft.SharePoint.Client.CamlQuery]::CreateAllItemsQuery(100)
$colItems = $list.GetItems($camlQuery)
$ctx.Load($colItems)
$ctx.ExecuteQuery();

#アイテム表示 ※ここが上手くいかない
write-host $colItems

データCSVの読み込み

$csv = Import-Csv "C:\Users\hhatanaka\Desktop\src\yoko\csv.csv"

アイテム作成処理の予約

foreach($line in $csv){

# アイテム作成の準備 $itemCreateInfo = New-Object Microsoft.SharePoint.Client.ListItemCreationInformation # 作成アイテムの情報設定 $newItem = $list.AddItem($itemCreateInfo) $newItem["社員名"] = $line.社員名 ※ここが上手くいかない、$newItem["社員名"]がない $newItem["順位"] = $line.順位 $newItem["実績"] = $line.実績 $newItem["達成率"] = $line.達成率 $newItem.Update()

}

作成処理の実行

$ctx.ExecuteQuery();

試したこと

よろしくお願いします。

補足情報(FW/ツールのバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問