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}
回答2件
あなたの回答
tips
プレビュー