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

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

ただいまの
回答率

87.49%

どう見ても存在するファイルがNotFound

解決済

回答 4

投稿

  • 評価
  • クリップ 1
  • VIEW 14K+

score 166

写真のような感じで、どう見ても同階層にファイルが存在するのに、
FileNotFoundError: [Errno 2] No such file or directory: 'sample_weight.pkl'
のエラーが出ます。

イメージ説明

ソースコード

# coding: utf-8
import numpy as np
import pickle
from mnist import load_mnist

def sigmoid(x):
    return 1 / (1 + np.exp(-x))    

def softmax(x):
    if x.ndim == 2:
        x = x.T
        x = x - np.max(x, axis=0)
        y = np.exp(x) / np.sum(np.exp(x), axis=0)
        return y.T 

    x = x - np.max(x) # オーバーフロー対策
    return np.exp(x) / np.sum(np.exp(x))


def get_data():
    (x_train, t_train), (x_test, t_test) = load_mnist(normalize=True, flatten=True, one_hot_label=False)
    return x_test, t_test


def init_network():
    with open("sample_weight.pkl", 'rb') as f:#問題の箇所
        network = pickle.load(f)
    return network


def predict(network, x):
    W1, W2, W3 = network['W1'], network['W2'], network['W3']
    b1, b2, b3 = network['b1'], network['b2'], network['b3']

    a1 = np.dot(x, W1) + b1
    z1 = sigmoid(a1)
    a2 = np.dot(z1, W2) + b2
    z2 = sigmoid(a2)
    a3 = np.dot(z2, W3) + b3
    y = softmax(a3)

    return y


x, t = get_data()
network = init_network()
accuracy_cnt = 0
for i in range(len(x)):
    y = predict(network, x[i])
    p= np.argmax(y) # 最も確率の高い要素のインデックスを取得
    if p == t[i]:
        accuracy_cnt += 1

print("Accuracy:" + str(float(accuracy_cnt) / len(x)))

(ゼロから始めるディープラーニング より)

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 4

+3

カレントディレクトリがDeepLearningなので、
deep-learning-from-scratch-master/ch03/sample_weight.pklを開く必要があるのでは?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

checkベストアンサー

+2

ファイル名が間違っていないのならば、カレントディレクトリが違うのでしょう。
open("sample_weight.pkl", 'rb')は、ソースプログラムと同じディレクトリのsample_weight.pklを開くんじゃなくて、カレントディレクトリのsample_weight.pklを開きます。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/09/26 21:01

    なるほど。 VSコードではカレントディレクトリがソースプログラムのディレクトリと同じとは限らないのですね。
    そのうえで質問なのですが、コードはどのように書けばいいのでしょうか?
    コマンドラインでたたいたところうまくいったので、単純にファイル名に ch3/ とつければいいという問題でもない気はするのですが。

    キャンセル

  • 2018/09/26 21:10

    os.path.dirname(os.path.abspath(__file__)))
    で、スクリプトファイルのディレクトリが分かるので、それ+"/sample_weight.pkl" で。

    キャンセル

0

質問や別の方の回答やコメントから推察して検索していたら便利そうなものを見つけたのでご参考までに。
Pythonで実行ファイルの場所(パス)を取得するfile

import os

print('getcwd:      ', os.getcwd())
print('__file__:    ', __file__)

出力結果

getcwd:       C:\workspace\Python\memo
__file__:     C:\workspace\Python\memo\sample.py

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/09/26 21:18

    __file__ って、実行の仕方によっては相対パスなので、そのあたりの考慮が要るかも。条件によっては要らないかも。

    キャンセル

  • 2018/09/26 21:19

    そうですね。
    とりあえずこんなサンプルあるのでリンク先見ればやりたいこと出来ると思いますってつもりでした。

    キャンセル

  • 2018/09/26 21:21

    はい。両方使えば出来ますね。

    キャンセル

  • 2018/09/26 21:23

    os.path.dirname(os.path.abspath(__file__)))
    と同じコードもリンク先にそのままありました。
    リンク見ないで回答出来るって流石です。

    キャンセル

0

参考情報

...
import os
# Look to the path of your current working directory
working_directory = os.getcwd()
file_path = working_directory + 'my_file.py'
...
import os
# Look for your absolute directory path
absolute_path = os.path.dirname(os.path.abspath(file))
file_path = absolute_path + '/folder/my_file.py'
...

fullpath でなくても cwd を把握していれば、そこからの相対パスで指定することも可能です。

あるいはプログラムの中で "./testtesttest.txt" などのような他にはなさそうな名前でファイルを作成してみて、実際にどこにそのファイルができたかを調べることで "." がどこを指しているか確認するのもよいかもしれません。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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