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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

1378閲覧

javasciptを使用して、input fileからローカルのCSVファイルを読み込みしたい。

mee12

総合スコア101

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2022/06/08 01:58

編集2022/06/08 03:31

javasciptを使用して、input fileからローカルのCSVファイルを読み込みしたいです。

最初に、コードからcreateElementして、new Event("click")から、dispatchで発火したいのですが、うまくできませんでした。

eventが発火できないので、consoleには警告は出ずでした。

createElementについては、input type="file"で使えるかはわかっていないですが、
html側で作成する必要があるかもしれません。

どなたかわかるかたいらっしゃいましたらお願いします。

javascript

1function buttonClicked() { 2 // createElementでinput type="file"を使えるかはわかっていない 3 let input = document.createElement("input"); 4 input["type"] = "file"; 5 input["accept"] = "text/csv"; 6 7 // イベント発火 8 let event = new Event("click"); 9 input.dispatchEvent(event); 10 11 input.addEventListener("change", function (event) { 12 if (event.target.files.length) { 13 // 1つ目ファイル 14 let file = event.target.files[0]; 15 16 // 拡張子の確認 17 if (!file.type.match("*.csv")) { 18 alert("csvファイルを選択して下さい。") 19 return; 20 } 21 22 // FileReaderを作成 23 let fileReader = new FileReader(); 24 25 // データ読み込み ※実際にはいろいろ文字列処理をしてから使う 26 fileReader.onload = (() => { 27 console.log(fileReader.result); 28 ); 29 } 30 }, false); 31}

(追記)
教えて頂いた方法から、実際に動作できたコードを記載します。

javascript

1buttonClicked() { 2 let id = document.getElementById("file"); 3 id ? id.remove() : ""; 4 5 let input = document.createElement("input"); 6 input["id"] = "file"; 7 input["type"] = "file"; 8 input["accept"] = "text/csv"; 9 input.setAttribute("hidden", 1); 10 document.body.appendChild(input); 11 12 input.click(); 13 14 input.addEventListener("change", (event) => { 15 if (event.target.files.length) { 16 // 1つ目ファイル 17 let file = event.target.files[0]; 18 19 // ファイルタイプの確認 20 if (!file.type.match("text/csv")) { 21 alert("csvファイルを選択して下さい。") 22 return; 23 } 24 25 // FileReaderを作成 26 let fileReader = new FileReader(); 27 28 // CSVファイルを取得 29 fileReader.readAsText(file); 30 31 // CSVファイルをロード 32 fileReader.onload = (event) => { 33 let text = event.target.result; 34 35 // 1行ごとに配列にする 36 let rows = text.split("\r\n"); 37 38 // 配列の末尾がなければ削除 39 if (!rows.slice(-1)[0]) { 40 rows.pop(); 41 } 42 43 // カンマでsplit 44 let data = rows.map((currentValue) => { 45 let row = currentValue.split(","); 46 return row; 47 }, []); 48 49 // データ確認用 50 console.log(data); 51 }; 52 53 // エラー処理 54 fileReader.onerror = function () { 55 alert("ファイルを読み込みできません。"); 56 }; 57 } 58 }, false); 59}

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

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

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

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

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

mee12

2022/06/08 02:13 編集

質問を修正済み
guest

回答2

0

ベストアンサー

js

1 let input = document.createElement("input");

この要素を、ページのどこかに繋げないとファイル選択ダイアログは開けません。例: document.body.appendChild(input);

js

1 // イベント発火 2 let event = new Event("click"); 3 input.dispatchEvent(event);

input.click() でいいです。
このコードがある buttonClicked()という関数がユーザによるマウスクリックなどを起点として実行されるなら、input.click() でファイル選択ダイアログを開けます。ページロード時に呼ばれるとかタイマーで呼ばれるなど、ユーザの行動から呼ばれるものではない場合、ファイル選択ダイアログは開けません。

投稿2022/06/08 02:25

int32_t

総合スコア20872

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

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

mee12

2022/06/08 02:29

ご回答ありがとうございます。 まずbodyに追加しないと動かないですよね。 eventの使い方もご丁寧に教えて頂きありがとうございます。 この方法でできそうですね。 教えて頂いた方法で実行できるか試します。 もう少々お待ちください。
mee12

2022/06/08 02:59

イベント発火も教えて頂いた方法でできました。ありがとうございます。 シンプルにclickでいいですね。 htmlは要素があれば、毎回removeしないとどんどん増えていってしまうため、削除するように追加しました。 動作はしているようなのですが、もう少し検証してみます。 -- let id = document.getElementById("file"); id ? id.remove() : ""; -- あとはFileReaderまわりの間違いを修正し、動作させることができました。 ありがとうございました。
guest

0

buttonClicked()の呼び出し方次第でしょうね
無手順でファイルダイアログを出そうとしても無理ですがクリック自体は認識されます
ユーザー側の任意の処理で呼び出せばダイアログは表示されます

javascript

1<script> 2function buttonClicked(){ 3 if(document.querySelector('#myfile')) myfile.remove(); 4 const fileElement = document.createElement("input"); 5 fileElement.type="file"; 6 fileElement.id="myfile"; 7 fileElement.setAttribute('hidden',1); 8 fileElement.addEventListener('click',()=>alert('file')); 9 document.body.appendChild(fileElement); 10 fileElement.click(); 11} 12window.addEventListener('DOMContentLoaded', ()=>{ 13 buttonClicked(); 14}); 15</script> 16<input type="button" value="btn" onclick="buttonClicked()">

※微調整

投稿2022/06/08 02:20

編集2022/06/08 02:51
yambejp

総合スコア114827

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

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

mee12

2022/06/08 02:28

ご回答ありがとうございます。 まずbodyに追加しないと動かないことがわかりました。 教えて頂いた方法で実行できるか試します。
mee12

2022/06/08 03:02 編集

イベント実行はint32_tさんの input.click() を使い、 input type="file"の非表示は、yambejpさんの方法を使いました。 教えて頂きありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問