【GAS】特定のフォルダ内(子フォルダ、孫フォルダ)のファイルをすべて取り出す方法

この記事は約4分で読めます。
スポンサーリンク
コピーボタン
記事のタイトルとURLをコピー
スポンサーリンク

【GAS】特定のフォルダ内(子フォルダ、孫フォルダ)のファイルをすべて取り出す方法

特定のフォルダの内のファイルをすべて取り出すプログラムを作りましたので、
参考にしてください。

コード

コードは下記の通りとなります。

最初だけ、ファイルを取り出したいフォルダを選択し、
それ以降はそのフォルダ内にある、子フォルダ、孫フォルダ、ひ孫フォルダ~~~~~まで、
自動で反復して検索してくれるようにしてあります。

function execution() {

  SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getRange(2, 1, 1000, 4).clearContent()
//特定のフォルダを指定する
  var Driveid = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getRange(1, 8).getValue()
//親となるフォルダを関数に渡す
  getPicID(Driveid)

}


function getPicID(Driveid) {

  // フォルダ内のファイルを一括取得
  var files = DriveApp.getFolderById(Driveid).getFiles();
  // 配列を宣言
  var Pic = [];
  // 配列に「名前」「URL」「ID」
  while (files.hasNext()) {
    //一括取得したファイルの中から順に一つ取り出す
    var file = files.next();
    //「名前」「説明」「URL」をそれぞれ格納
    Pic.push([
      file.getName(),
      file.getUrl(),
      file.getId(),
      "=image(\"https://drive.google.com/uc?id=" + file.getId() + "\")",

    ]);
  }
//最終行を取得
  var lastY = SpreadsheetApp.getActiveSpreadsheet().getLastRow()
//最終行に追加
  SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getRange(lastY + 1, 1, Pic.length, Pic[0].length).setValues(Pic)
//子フォルダを格納
  var childFolders = DriveApp.getFolderById(Driveid).getFolders();
//子フォルダがなくなるまで実行
  while (childFolders.hasNext()) {
    var childFolder = childFolders.next();
//子フォルダのIDを取得し、同じ関数に返す。
    getPicID(childFolder.getId())
  }

}

肝となる部分

肝となるのは、下に示す部分となっており、
1階層目の処理が終わった後に、その子フォルダ(2階層目)でも同様の処理を行います。
また、その子フォルダ内に子フォルダ(3階層目)があった場合も同様の処理を行います

というように、一見無限ループになるかのような処理を行っております。

function ★関数★(Driveid)~~~
~~~

//子フォルダを格納
  var childFolders = DriveApp.getFolderById(Driveid).getFolders();
//子フォルダがなくなるまで実行
  while (childFolders.hasNext()) {
    var childFolder = childFolders.next();
//子フォルダのIDを取得し、同じ関数に返す。
    ★関数★(childFolder.getId())
  }

繰り返し処理には使えるやり方なので覚えておいて損はないです。

このコードの実際の動き

このコードの実際の動きは、下記ボタンより、
GASをコピーして実行してみてください。

コピーボタン
記事のタイトルとURLをコピー
GAS
スポンサーリンク
nujonoaをフォローする
nujonoa_blog

コメント欄

タイトルとURLをコピーしました