Google関連

[Google Apps Script]スプレッドシートをExcelファイル(xlsx)に変換する

スプレッドシートのファイルメニュー → 形式を指定してダウンロード → Microsoft Excel(.xlsx) から、スプレッドシートをExcelファイルに変換できますが、下記URLにIDを渡すことで同じ処理ができることを、今さらながらに知りました。

https://docs.google.com/spreadsheets/d/(スプレッドシートのID)/export?format=xlsx

折角なので、スプレッドシートをExcelファイル(xlsx)に変換し、ドライブ上に保存する簡単なスクリプトを書いてみました。

スプレッドシートのIDの取得方法は下記サイトをご参照ください。

function myFunction() {
  var id = "(スプレッドシートのID)";
  var excel_file = ss2xlsx(id);
  if (excel_file !== undefined) {
    Logger.log("Name:" + excel_file.getName());
  }
}

//SpreadsheetをExcelファイルに変換してドライブに保存、Fileを返す
function ss2xlsx(spreadsheet_id) {
  var new_file;
  var url = "https://docs.google.com/spreadsheets/d/" + spreadsheet_id + "/export?format=xlsx";
  var options = {
    method: "get",
    headers: {"Authorization": "Bearer " + ScriptApp.getOAuthToken()},
    muteHttpExceptions: true
  };
  var res = UrlFetchApp.fetch(url, options);
  if (res.getResponseCode() == 200) {
    var ss = SpreadsheetApp.openById(spreadsheet_id);
    new_file = DriveApp.createFile(res.getBlob()).setName(ss.getName() + ".xlsx");
  }
  return new_file;
}

上記コードを実行すると、問題が無ければ同名のExcelファイルがドライブ上に作成されます。

下記サイトを参考にした処理ですが、こちらは変換したファイルを直接メール送信しています。

関連記事

日本標準時(JST)を取得するVBAマクロ前のページ

2019年7月の人気記事次のページ

関連記事

  1. Google関連

    [Google Apps Script]郵便番号から住所を取得する自作関数と住所から地図画像のURL…

    郵便番号検索APIを使って郵便番号から住所を取得する自作関数と、Sta…

  2. Office関連

    Google スライドで新規プレゼンテーションを作成するVBAマクロ

    ここ数日PowerPointのマクロに加え、Google Apps S…

  3. Google関連

    [Google Apps Script]スプレッドシートのセル範囲に指定した値が含まれているかを判定…

    先日、もり(@moripro3)さんから、「スプレッドシートの二次元配…

  4. Google関連

    [Google Apps Script]insertTextBoxメソッドでスライドにテキストボック…

    昨年の9月にスライド上にテキストボックスを挿入するスクリプトについて記…

  5. Google関連

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

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

  6. Office関連

    Gmail APIを使ってメール送信するVBAマクロ

    「「Gmail API」β版公開、連動アプリ開発を支援」にもあるように…

コメント

  • コメント (0)

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

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

Time limit is exhausted. Please reload CAPTCHA.

※本ページはプロモーションが含まれています。

Translate

最近の記事

アーカイブ

PAGE TOP