Apps Scriptリファレンス: Apps Script Reference |障害・課題追跡: IssueTracker |Google Workspace: Status Dashboard - Summary

2019年4月29日月曜日

Googleドライブのフォルダ内でファイル名が一致するドキュメントのテキストを取得したい


Googleドライブのフォルダ内のドキュメントからテキストを取得したい(並べ替える)
ではフォルダ内のすべてのファイルを対象にしましたが

ここでは
フォルダ内に存在するすべてのファイルを取得してから
その中でファイル名が一致するものだけを抽出する

というコードを書きました


以下の変数内の値は各自で設定します
  • folder の ID
  • files のファイル名を特定する文字列

コード.gs
function getFilesBySearch0() {
  var folder = DriveApp.getFolderById("ID");
  var files = folder.searchFiles('title contains "ファイル名を特定する文字列"');
  
  var fileProps = [];
  while (files.hasNext()) {
    var file = files.next();
    var id = file.getId();
    var name = file.getName();
    var text = getDocText(id);
    var obj = {}
    obj['id'] = id;
    obj['name'] = name;
    obj['text'] = text;
    fileProps.push(obj);
  }
  objSort(fileProps);
  Logger.log(fileProps);
  console.log(fileProps);
}

/************************************
ドキュメントのテキストを取得する
************************************/
function getDocText(id) {
  var doc = DocumentApp.openById(id);
  var text = doc.getBody().getText();
  return text;
}

/************************************
並べ替える
************************************/
function objSort(fileProps) {
  var ascending = fileProps.sort(asc);
  return ascending;
}

/************************************
nameで昇順に並べ替える
************************************/
function asc(a, b){
  var A = a.name;
  var B = b.name;
  if(A > B){
    return 1;
  }else if(A < B ){
    return -1;
  }else{
   return 0;
  }
}



補足

フォルダ内のファイル数が多いとその分時間がかかります


関連記事
Googleドライブ内の特定のフォルダ内でファイルを探したい(スクリプトで)
Googleドライブのフォルダ内のドキュメントからテキストを取得したい(並べ替える)

Latest post

Google Formsで記述式の質問に字数制限を設定したい

記述式の質問には「回答の検証」を設定することができます フォームの編集画面 右下の︙メニューで「回答の検証」を選択します 検証方法には「数値」「テキスト」「長さ」「正規表現」という種類があります 今回は字数制限したいので「長さ」を選びます 長さには「最大文字数」か「最小文字数」を...