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

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

ただいまの
回答率

88.37%

exeにパッケージした時、上階層のファイルを読み取るには?

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 547

kihokutarou

score 24

ある制限のある環境下で以下の制作をしています。ほかの言語だと楽だとは思うのですが・・・。
・Htmlでjavascriptを使用しながらファイルを作成
→同じ階層のcsvファイルからランダムにセルを表示させるスクリプト
・nwjs(node-webkit)を利用し実行ファイル形式にパッケージング
・Enigmaで単体実行ファイルにまとめる (この場合1.exeと仮にします)

この際、主となるindex.htmlとsample.csvは同一階層に存在し、その場合上記手順を実行しても問題なく動きます。

やりたいこととしては、
・1.exeと同階層にsample.csvを置きユーザーが自由にcsvを編集して使えるようにしたい。
と思い、csvファイルをhtmlファイルの上階層に指定(../や../../など)にしてみましたが、パッケージにすると動きません。
※var data = csvToArray("../sample.csv"); など。
1階層上から5階層上まで試しましたが動きません。そもそもそういった手順では無理なのか・・・。

上記手順を踏んだ場合、exeにすると何階層上になるのか、どのような記述をすべきなのか、解決方法をご教示ください。または代替案があれば教えていただけるとありがたいです。

sample.csvはExcelでいうA列に1から順の連番、B列に表示させたい項目(この場合掛け算九九を入れてみました)が入っているものです。

<!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()
{
  //関数hyoji()を1000ミリ秒間隔で呼び出す
  setInterval("miru()",2000);
}
function stopTimer(){

location.reload();

}

</script>


</body>
</html>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+1

NW.js使ってるんですよね?
動かしてるのはローカルですよね?
どうしてCSVファイルを通信して取ってこようとするんでしょうか?
別サーバに置いてある…わけじゃないですよね。

公式ドキュメントの以下を参照してください。
Example 3 - Using Node.js API

Node.jsのAPI使えるので、fsとか使ってローカルファイルアクセスすればいいだけでは?

Node.js - File System

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

electronならファイルアクセス可能だと思います。調べて見て下さい。(vs codeとかの基盤です。)

ただelectronの内部環境はnode.jsなので今のソースの修正が必要かと思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/10/03 12:24

    追記。

    質問に書いてある 制限は明記したほうが良いです。必須ですね。
    回答したあとで、いやそれは制限でダメですとか言われると回答付かなくなります。

    キャンセル

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

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

関連した質問

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