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

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

ただいまの
回答率

88.64%

javascriptにて任意のCSVを読み込みたい

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 2,770

kihokutarou

score 24

sample.csvを読み込み、シャッフルされたものの中から一つ取り出して一定時間ごとに切り替えるプログラムを書きました。計算のフラッシュカードのイメージです。

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>フラッシュカード</title>
<style type="text/css">
#aaaa{
 color:white;
 text-align:center;
 background-color:black;
 font-size: 500px;
}
a.cp_btn {
display: block;
width: 160px;
padding: 0.8em;
text-align: center;
text-decoration: none;
color: #EC407A;
border: 2px solid #EC407A;
border-radius: 3px;
transition: .4s;
}
a.cp_btn:hover {
background: #EC407A;
color: #fff;
}
</style>
</head>
<body>
<a class="cp_btn" onclick="startfnc()">スタート</a><br>
<div id="aaaa">問題</div><br>
<a class="cp_btn"  onclick="stopTimer()">ストップ</a>


<script>

//配列をシャッフルする
function shuffle(array) {
  var n = array.length, t, i;

  while (n) {
    i = Math.floor(Math.random() * n--);
    t = array[n];
    array[n] = array[i];
    array[i] = t;
  }

  return array;
}


// CSVファイル読み込み
function csvToArray(path) {
    var csvData = new Array();
    var data = new XMLHttpRequest();    
    data.open("GET", path, false);
    data.send(null);
    var LF = String.fromCharCode(10);
    var lines = data.responseText.split(LF);
    for (var i = 0; i < lines.length;++i) {
        var cells = lines[i].split(",");
        if( cells.length != 1 ) {
            csvData.push(cells);
        }
    }
    return csvData;
}

//csvからdivにランダムで書き出す
function miru(){
    var data = csvToArray("sample.csv");
    shuffle(data);
    var p = document.getElementById('aaaa');

    p.innerHTML = data[0][1] //テキストを変更

    console.log(p.innerHTML);

    //alert(data[0][0]);
}
function startfnc()
{
  //関数miru()を1000ミリ秒間隔で呼び出す
  setInterval("miru()",2000);
}
function stopTimer(){

location.reload();

}

</script>


</body>
</html>

本体と同一階層にあるcsvファイルで、A列に通し番号、B列に「2×3」のような問題がずらっと並んでいます。
このCSVファイルを、ユーザーが任意の場所から読み込むことはできないでしょうか。
File APIを利用して読み込めばいいのかなと思うのですが、どこから手を付けていいかりません。どなたかご教示お願いできないでしょうか。
よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

CSVでやれないことはないですが、読み込みが同じドメイン内から一回だけしかしないなら
jsonデータでやるほうが良いでしょう。
ついでにいえばjsファイルにしておけばajaxで処理せずに済むのでデータ処理は楽になります。
(jQueryなど利用せずにajaxを処理するのは面倒なので)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/14 16:18

    ご回答ありがとうございます。
    jsonも考えたのですが、ユーザーが作成やすいファイルとなるとCSVになります。また読み込みに関しても何回も読み込むことが想定されます。

    キャンセル

  • 2018/11/14 16:26

    むしろ「ユーザーが作成やすいファイル」となると、デリミタやエンクロージャ、
    エスケープ処理などブレなどでてくるのでバグの温床になりそうですね
    任意の場所がサーバー上に公開されているファイルなのか、
    ユーザーがアップロードしてつかうかにもよりますので仕様をつめてください

    キャンセル

  • 2018/11/14 16:40

    後だしで申し訳ありません。
    オフライン環境課で動かそうと思っています。したがって読み込むファイルもローカルにあるものを読み込む感じですね。
    ユーザーがExcel等でcsvを作成する→htmlで読み込んで表示する
    といった流れです。

    キャンセル

+1

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/11/14 19:04

    textareaあたりにexcelの領域をコピペさせた方が早い気がしてきました。

    キャンセル

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

  • ただいまの回答率 88.64%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る