GASでローカルのCSVを読み込んで、
CSVの内容をスプレッドシートに表示させようとしています。
しかし、CSVファイルを選択して読み込んでも、
スプレッドシートに何も表示されないままの状態になってしまいます。
CSVのデータが多すぎるのが原因かと思っています。
やりたいことは、「7,700KB」のCSVを読み込もうとしています。
CSVのデータを少なくして同様の処理を行うと、
CSVの内容がスプレッドシートに表示されます。
CSVのデータが多くても、
スプレッドシートに表示させるためにはどうすれば宜しいでしょうか。
以下、GASのコードを添付致します。
恐れ入りますが、ご教示頂けますと幸いです。
function main() { var html = HtmlService.createHtmlOutputFromFile("dialog"); SpreadsheetApp.getUi().showModalDialog(html, 'ローカルファイル読込'); } function writeSheet(formObject) { // フォームで指定したテキストファイルを読み込む var fileBlob = formObject.myFile; // テキストとして取得(Windowsの場合、文字コードに Shift_JIS を指定) var text = fileBlob.getDataAsString("Shift_JIS"); // 書き込むシートを取得 var ash = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ash.getSheetByName(""); //スプレッドシートのデータを削除する var lastRow, lastCol; lastRow = sheet.getLastRow(); lastCol = sheet.getLastColumn(); sheet.getRange(1,1,lastRow,lastCol).clearContent(); var csv = Utilities.parseCsv(text); //CSVの内容をスプレッドシートのA1セルから書き込んでいく sheet.getRange(1,1,csv.length,csv[0].length).setValues(csv); <!DOCTYPE html> <html> <head> <!--- <base target="_top"> ---> <base target="_top"> <script> // すべてのフォームをイベントリスナーに登録する function preventFormSubmit() { var forms = document.querySelectorAll('form'); for (var i = 0; i < forms.length; i++) { forms[i].addEventListener('submit', function(event) { event.preventDefault(); }); } } window.addEventListener('load', preventFormSubmit); // フォームのサブミットで呼ばれる処理 function readFile(formObject) { // GASで定義した関数を呼び出す google.script.run.writeSheet(formObject); } </script> </head> <body> <form id="myForm" onsubmit="readFile(this)" enctype="multipart/form-data"> <input name="myFile" type="file" /><br> <button type="submit">読込</button> </form> </body> </html>
回答1件
あなたの回答
tips
プレビュー