Export Sharepoint List to a Excel file automatically by powershell

Sharepointリストの読み込み

SharepointリストをPowershellで扱うにはCSOMライブラリを使います。
リスト更新方法についての記事にライブラリの使い方の詳細を書いてますので、そちらを参照してください。ライブラリの読み込みから解説してます。

SharepointリストをPowershellで更新する

下記を行って$itemにリストアイテムを読み込んだ前提で以下をお読みください。

$itemを読み込むと、テキストはテキストで、オブジェクトはオブジェクトのまま入っています。
Excelに取り出すときは平文で取りたいはずです。ですので表示用のTextを取得するために、下記のプロパティを使います。

このFieldValuesAsTextプロパティを利用してリストアイテムの行が取得できます。

ということで、ちょっと前に戻ってリスト全体を取得してから各アイテムのFieldValuesAsTextプロパティを取ることで必要な情報を取得できます。

まずは、CamlQueryの指定。これはxmlで取得するデータを指定するものですが、何も指定しなければ、リスト全体を取得します。

結果を格納する空の配列を作ります。

要素付き配列($Row)を宣言して、要素を設定して$RptCollectionに追加していきます。

これで$RptCollectionに値が配列として入ります。これをExportすればOKです。

Export-Csvでも良いんですが、おすすめはExport-Excelコマンドレットです。直接xlsxファイルになりますし機能も豊富です。グラフやピボットテーブルを作ることも可能です。

ImportExcelモジュールに含まれています。詳しくは下記をご覧ください。

Export-Excelコマンドレットの使い方【ImportExcel】【Powershell】

全体のScriptとしては以下の通りです。

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください