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

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

ただいまの
回答率

89.62%

flask runの場合の実行環境がpython3と異なる?

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,495

osasai

score 14

前提・実現したいこと

仮想環境で、

>flask run

を実行したときに、
ModuleNotFoundError: No module named 'psycopg2'
というエラーがでてしまいます。

一方で、同じプログラムを同じ環境で、

>python3 app.py

と行うと正しく実行されるようです。

こちら、flask runの場合に、モジュールのインポートエラーが出てしまう理由としては、何が考えられるでしょうか?

他のサイトなどで、pipによるインストールが該当の仮想環境になっていないというケースがあるというのを聞き、
>pip3 freeze
で確認しても、ただしくインストールがされているようでした。(そもそも、それだとインラインや、python3 app.pyで実行されるのも不思議。ありそうなのは、flask runの実行環境が、何かの設定でおかしな事になっているということでしょうか)

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

Error: While importing "app", an ImportError was raised:

Traceback (most recent call last):
  File "/usr/local/lib/python3.7/site-packages/flask/cli.py", line 235, in locate_app
    __import__(module_name)
  File "/Users/osasai/Documents/01_Study/Python/project/flaskApp/app.py", line 2, in <module>
    import psycopg2
ModuleNotFoundError: No module named 'psycopg2'

該当のソースコード

from flask import Flask, render_template, request
import psycopg2
import psycopg2.extras

app = Flask(__name__)

conn = psycopg2.connect("dbname=flasknote")
cur = conn.cursor(cursor_factory=psycopg2.extras.DictCursor)

@app.route('/',methods=['GET'])
def index():
    cur.execute('SELECT * FROM messages')
    messages = cur.fetchall()
    messages = [ dict(message) for message in messages]
    return render_template('index.html', messages=messages)


@app.route('/post', methods=['GET'])
def form():
    if request.method == 'GET':
        return render_template('form.html')

試したこと

・pip3 freezeの実施
・PyCharmでのインラインでの実行(→エラーにならず、動きました)

補足情報(FW/ツールのバージョンなど)

MacOS Mojave
「PythonでWebサービスを作る Python3+Flaskで作るWebアプリケーション開発入門2 (中野 仁 著)」7.2章のテストコード

(flaskApp) OsamunoMacBook-Pro:flaskApp osasai$ pip3 freeze
Click==7.0
Flask==1.0.2
itsdangerous==1.1.0
Jinja2==2.10
MarkupSafe==1.1.1
psycopg2==2.7.7
psycopg2-binary==2.7.7
Werkzeug==0.15.1
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

考えていること

仮想環境と仮想ではない環境の両方から Flask を削除し、再度仮想環境に だけ Flask をインストールしたら、症状が改善するのではないかと考えております。

確認いただきたいこと

1, 2 が異なれば上記提案で症状が改善するのではないかと考えております。

1. which python3

以下の実行結果を教えていただけますでしょうか?

(仮想環境)$ which python3
実行結果 <-- これです。
(仮想環境)$ 

2. which flask と cat

シェバン を教えていただけますでしょうか?

(仮想環境)$ which flask
/path/to/flask
(仮想環境)$
(仮想環境)$ # which flask の実行結果を cat する。
(仮想環境)$ cat /path/to/flask
#!/path/to/python  <-- これです。
# -*- coding: utf-8 -*-
import re
import sys

from flask.cli import main

if __name__ == '__main__':
    sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0])
    sys.exit(main())
(仮想環境)$

3. sys.path

あまり関係ないかもしれませんが、以下のコードの実行結果も合わせて教えていただけると幸いです。

(仮想環境)$ # 対話モードを開き
(仮想環境)$ python3
>>> # 以下のコードの実行結果を教えてください。
import sys
sys.path
print(*sys.path, sep="\n")

そのように考えた背景

ご提示いただいたエラーに "/usr/local/lib/python3.7/site-packages/flask/cli.py" という文字が見えます。これは仮想環境下ではない Flask が起動している可能性があるのではないかと疑っております、さらに、もしかしたら仮想環境下にない Python が起動している可能性があるのではないかと考えております。

Error: While importing "app", an ImportError was raised:

Traceback (most recent call last):
  File "/usr/local/lib/python3.7/site-packages/flask/cli.py", line 235, in locate_app
    __import__(module_name)
  File "/Users/osasai/Documents/01_Study/Python/project/flaskApp/app.py", line 2, in <module>
    import psycopg2
ModuleNotFoundError: No module named 'psycopg2'

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/24 01:42

    > sys.path の実行優先順位がグローバルになってしまっているのが原因なんでしょうかね?
    sys.path は先頭から参照されるため、sys.path の順番をいれかえただけでも正常に動作したのではと思います。ただ、直接誰が悪さをしているのかは、わかりません。

    Flask は import が鬼門で python app.py と flask run で sys.path の内容が変わるので、そのあたりもお気をつけいただければと思います。

    キャンセル

  • 2019/03/24 02:04

    ありがとうございます!
    やはりトライしてみないとわからないですね!非常に参考になりました!

    キャンセル

  • 2019/03/24 02:06

    恐れ入ります!

    キャンセル

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

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