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

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

ただいまの
回答率

87.37%

PC上で問題なく動くアプリケーションが、PythonAnywhereにアップロードすると、エラーが出るのはなぜ?

解決済

回答 2

投稿 編集

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

score 15

 前提・実現したいこと

初心者です。Python機械学習プログラミング[第2版]で勉強中です。
第9章 9.4.1で映画レビュー分類アプリケーションを作成しました。
ローカルサーバーで起動したらうまくいったのですが、

PythonAnywhereにファイルをアップロードしてWebを見ようとすると、
以下のエラーログが出ます。

 発生している問題・エラーメッセージ

2018-09-23 12:36:22,227: Error running WSGI application
2018-09-23 12:36:22,232: FileNotFoundError: [Errno 2] No such file or directory: '/home/1976kaca/pkl_objects/stopwords.pkl'
2018-09-23 12:36:22,233:   File "/var/www/1976kaca_pythonanywhere_com_wsgi.py", line 16, in <module>
2018-09-23 12:36:22,233:     from movieclassifier import app as application  # noqa
2018-09-23 12:36:22,233: 
2018-09-23 12:36:22,233:   File "/home/1976kaca/movieclassifier/app.py", line 8, in <module>
2018-09-23 12:36:22,233:     from vectorizer import vect
2018-09-23 12:36:22,233: 
2018-09-23 12:36:22,234:   File "/home/1976kaca/vectorizer.py", line 10, in <module>
2018-09-23 12:36:22,234:     'stopwords.pkl'), 'rb'))

app.pyのソースコードは以下です。

from flask import Flask, render_template, request
from wtforms import Form, TextAreaField, validators
import pickle
import sqlite3
import os
import numpy as np

from vectorizer import vect

app = Flask(name)

cur_dir = os.path.dirname(file)
clf = pickle.load(open(os.path.join(cur_dir, 'pkl_objects', 'classifier.pkl'),
'rb'))
db = os.path.join(cur_dir, 'reviews.sqlite')

def classify(document):
label = {0: 'negative', 1: 'positive'}
X = vect.transform([document])
y = clf.predict(X)[0]
proba = clf.predict_proba(X).max()
return label[y], proba

def train(document, y):
X = vect.transform([document])
clf.partial_fit(X, [y])

def sqlite_entry(path, document, y):
conn = sqlite3.connect(path)
c = conn.cursor()
c.execute("INSERT INTO review_db (review, sentiment, date)"\
" VALUES (?, ?, DATETIME('now'))", (document, y))
conn.commit()
conn.close()

class ReviewForm(Form):
moviereview = TextAreaField('',
[validators.DataRequired(),
validators.length(min=15)])
@app.route('/')
def index():
form = ReviewForm(request.form)
return render_template('reviewform.html', form=form)

@app.route('/results', methods=['POST'])
def results():
form = ReviewForm(request.form)
if request.method == 'POST' and form.validate():
review = request.form['moviereview']
y, proba = classify(review)
return render_template('results.html',
content=review,
prediction=y,
probability=round(proba*100, 2))
return render_template('reviewform.html', form=form)

@app.route('/thanks', methods=['POST'])
def feedback():
feedback = request.form['feedback_button']
review = request.form['review']
prediction = request.form['prediction']

inv_label = {'negative': 0, 'positive': 1}
y = inv_label[prediction]
if feedback == 'Incorrect':
y = int(not(y))
train(review, y)
sqlite_entry(db, review, y)
return render_template('thanks.html')

if name == 'main':
app.run()

 試したこと

movieclassifierディレクトリをベースとして、動くアプリケーションのはずが、
1976kacaディレクトリからpkl_objectsや、vectorizer.pyを読もうとして失敗していると
読み解いたのですが。

WEb上でも
movieclassifier
|_app.py
|_pkl_objects
|  |_classifier.pkl
|  |_stopwords.pkl
|_reviews.sqlite
|_static
|  |_style.css
|_templates
........
とフォルダーの配置などは同じにしてあるのですが、何が間違っているのでしょうか?
教えていただければ幸いです。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+1

ファイルが見つからないというエラーです。
カレントディレクトリが想定と違ってるということなんで、そこらへん調べてみよう

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/09/26 23:19 編集

    ありがとうございます。ビギナー設定なので、ターミナルからログインできないことがわかりました。

    キャンセル

  • 2018/09/26 23:27

    で、エラーメッセージは変わっていませんか?
    最初のエラーでは、
    /home/1976kaca/pkl_objects/stopwords.pkl というファイルがない、ということでしたが

    キャンセル

  • 2018/09/27 20:42 編集

    返信が遅れてすみません。
    PythonAnywhereのコンソールで、movieclassifierディレクトリに移動し、格納されているファイル、フォルダを確認したら、すべてありました。
    home/1976kaca/pk_objectsという構成ではありませんでした。
    home/1976kaca/movieclassifier/pkl_objects/stopwords.pklにしたいのですが、、、
    app.pyのどこをどう直せばいいのでしょうか?

    キャンセル

check解決した方法

0

WSGI configuration file:
/var/www/1976kaca_pythonanywhere_com_wsgi.py (太字部分)を書き換えることで、
映画レビュー入力画面 → フィードバック入力画面までは表示できるようになりました。

# This file contains the WSGI configuration required to serve up your
# web application at http://<your-username>.pythonanywhere.com/
# It works by setting the variable 'application' to a WSGI handler of some
# description.
#
# The below has been auto-generated for your Flask project

import sys

# add your project directory to the sys.path
project_home = u'/home/1976kaca**/movieclassifier**'
if project_home not in sys.path:
    sys.path = [project_home] + sys.path

# import flask app but need to call it "application" for WSGI to work
from **app** import app as application  # noqa

フィードバックから先はInternal Server Errorと表示されてうまくいきません。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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