Google関連

[Google Apps Script]Google ドライブにあるファイルをファイル名順で出力する

以前書いた「Google ドライブにある画像をスライドに一括挿入するGASコード」を元に、ファイル名順に画像を挿入したい、というクラウドワークス依頼を見つけました。

これに関連して、Shinji(@sakichi01_)さんから、Folder.getFilesメソッドにはソート機能が備わっていないという情報をいただきました。

となると、スプレッドシートを使ってファイル名で並べ替えたり、配列に格納してソートしたり、何かしらの処理を挟む必要がありますが、リファレンスを眺めていたら、拡張サービス(Advanced Drive Service)の方にはorderByパラメーターが用意されているのを見つけました。

これを使えば、簡単にファイル名でソートできそうです。

指定したフォルダ内にあるJPEGファイルとPNGファイルの名前を降順で出力するスクリプト

試しに簡単な処理を書いてみました。
クラウドワークスに依頼が出ている以上、さすがに回答そのままな処理は書けないので、“指定したフォルダ内にあるJPEGファイルとPNGファイルの名前を降順で出力する”処理です。

function myFunction() {
  var folId = "(Google ドライブのフォルダID)";
  var list = Drive.Files.list({
    q: '"' + folId + '" in parents and (mimeType contains "jpeg" or mimeType contains "png")',
    spaces: 'drive',
    orderBy: 'title desc'
  });
  if(list.items.length > 0) {
    list.items.forEach(function(file) {
      Logger.log(file.title);
    });
  }
}

上記コードを実行する前に、リソース → Google の拡張サービス から、「Drive API」をオンにする必要があります。

また、検索に使用するクエリ文字列は、下記リファレンスをご参照ください。

拡張サービスを有効にする必要がありますが、より柔軟にファイル処理を行いたいときは、こちらを使った方が良いかもしれません。クエリによる検索も非常に便利です。

Office Scriptsってどんな機能?前のページ

「ics ファイルを作成する Power Automate での Flow の作り方」を試してみました。次のページ

関連記事

  1. Google関連

    [Google Apps Script]選択中のスライドに対してのみ処理を行う

    以前、Google スライドですべてのスライドに対して処理を行う方法に…

  2. Office関連

    Google翻訳で文字列を翻訳するマクロ

    ※ 2016/2 時点では下記の方法はもう使用できなくなっています。V…

  3. Google関連

    Google AdSenseで「PC のパフォーマンスが低下しています」を表示しないようにする。

    下記のサイトでも話題になっていますが、Google AdSenseの怪…

  4. Google関連

    Google Docs用アドオンを作成する。

    「Google Docs用アドオンストアがオープン、表計算や文書作成に…

  5. Google関連

    [Google Apps Script]jQuery UIのDatepickerを使ってスプレッドシ…

    「この記事のようにjQuery UIのDatepickerを使ってスプ…

  6. Word

    GoogleとYahoo!で同時に翻訳するWordマクロ

    「Google翻訳で文字列を翻訳するマクロ」と「Yahoo!翻訳で文字…

コメント

  • コメント (0)

  • トラックバックは利用できません。

  1. この記事へのコメントはありません。

Time limit is exhausted. Please reload CAPTCHA.

最近の記事

アーカイブ

PAGE TOP