質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

Q&A

解決済

1回答

2117閲覧

GASでローカルCSV(データ量が多い)を読み込んでスプレッドシートに表示させたいです

Yasu_Shima

総合スコア4

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

0グッド

0クリップ

投稿2020/01/27 23:31

編集2020/01/28 00:01

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>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_waiwai

2020/01/27 23:49

このままではコードが読みづらいので、質問を編集し、<code>ボタンを押し、出てくる’’’の枠の中にコードを貼り付けてください
Yasu_Shima

2020/01/28 00:01

ご連絡頂きありがとうございました。ご教示頂いた通り、質問を編集致しました。
papinianus

2020/01/29 22:49

実行時間制限があるので確認ですが、gsuiteを契約してますか?
Yasu_Shima

2020/02/02 05:09 編集

ご連絡頂きありがとうございます。 試行錯誤した結果、CSVデータに改行が含まれていたことが、スプレッドシートにインポートできない原因でした。 大変失礼いたしました。
guest

回答1

0

自己解決

自己解決しました。
CSVデータに改行が含まれていたことが、スプレッドシートにインポートできない原因でした。
CSVの改行を全て削除した結果、スプレッドシートにインポートできました。

投稿2020/02/02 05:10

Yasu_Shima

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問