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

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

ただいまの
回答率

90.22%

python-dotenvをpip install すると何が起きているのか?

解決済

回答 1

投稿 編集

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

urua

score 32

 前提・実現したいこと

この質問をさせて頂いてから判明したことがあったのでリンクします。

FlaskでWebアプリケーションを作成したいので少しずつ調べながらやってます。

Flaskのデバッグ中にpython-dotenvを推奨する警告が出たのでinstallしてみたところ、
権限エラーが発生するようになることが分かりました。

(間違いがあれば指摘いただけるとうれしいです。)
python-dotenvは、
環境変数などを管理し外部公開する時に重要な情報を見せないように利用されることは調べてみて分かったのですが
pip installを実行したことによって
何が変わってしまっているのか、何をしなければいけないのかが分からなかったので質問させて頂くことにしました。

python-dotenvを入れるにあたって、flaskではどのような設定が必要になるのでしょうか?
また、それは既存のファイルを書き換えますか?
それともapp.pyなどを任意の場所に作成して以下のような変数を宣言するのでしょうか?
FLASK_APP="Hoge"

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

pip install python-dotenv を実施すると下記ソースコードでPermissionErrorが起きる。

 該当のソースコード

from flask import Flask, render_template

app = Flask(__name__)


@app.route('/')
def index():
    return render_template('index.html')


if __name__ == '__main__':
    app.debug = True
    #ここでPermissionError
    app.run(host='127.0.0.1', port=8000)

 試したこと

同じソースでpython-dotenvがあればエラー、なければエラーにならないこと。

.envディレクトリの権限がUserがフルコントロールであること。(右クリック→プロパティ→セキュリティ)
表示されているすべてのユーザーを一時的にフルコントロールにしてみましたがダメでした。

VisualStudioCodeからではなく、PowerShellを管理者実行しても権限エラーが出た。

試しにプロジェクトの読取専用(一部)を外してみましたが、変わりませんでした。

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

Windows10 HOME 

VisualStudioCode

Python 3.6.6

(.env) > pip freeze
astroid==2.0.4
Click==7.0
colorama==0.3.9
Flask==1.0.2
isort==4.3.4
itsdangerous==0.24
Jinja2==2.10
lazy-object-proxy==1.3.1
MarkupSafe==1.0
mccabe==0.6.1
pylint==2.1.1
python-dotenv==0.9.1
rope==0.11.0
six==1.11.0
typed-ast==1.1.0
Werkzeug==0.14.1
wrapt==1.10.11


追記①

VSCode のターミナル(Bash)で実行

$ powershell
Windows PowerShell
Copyright (C) Microsoft Corporation. All rights reserved.

[PS](*'-')<D:\DevNotes\ProjectFolder> .env/Scripts/Activate
(.env) [PS](*'-')<D:\DevNotes\ProjectFolder> pip list
Package Version
----------------- -------
astroid 2.0.4
Click 7.0
colorama 0.3.9
Flask 1.0.2
isort 4.3.4
itsdangerous 0.24
Jinja2 2.10
lazy-object-proxy 1.3.1
MarkupSafe 1.0
mccabe 0.6.1
pip 18.1
pylint 2.1.1
python-dotenv 0.9.1
rope 0.11.0
setuptools 40.4.3
six 1.11.0
typed-ast 1.1.0
Werkzeug 0.14.1
wheel 0.32.1
wrapt 1.10.11
(.env) [PS](*'-')<D:\DevNotes\ProjectFolder> pip show python-dotenv
Name: python-dotenv
Version: 0.9.1
Summary: Add .env support to your django/flask apps in development and deployments
Home-page: http://github.com/theskumar/python-dotenv
Author: Saurabh Kumar
Author-email: me+github@saurabh-kumar.com
License: UNKNOWN
Location: d:\devnotes\ProjectFolder\.env\lib\site-packages
Requires:
Required-by:
(.env) [PS](*'-')<D:\DevNotes\ProjectFolder>

## インタープリタをPython3.6.6(virtualenv)
## デバッグをPython:Flask で実行

Traceback (most recent call last):
File "c:\program files (x86)\microsoft visual studio\shared\python36_64\Lib\runpy.py", line 193, in _run_module_as_main
"__main__", mod_spec)
File "c:\program files (x86)\microsoft visual studio\shared\python36_64\Lib\runpy.py", line 85, in _run_code
exec(code, run_globals)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\__main__.py", line 211, in <module>
singlesession=args.single_session)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\__main__.py", line 205, in main
debug_main(addr, name, kind, *extra, **kwargs)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_local.py", line 28, in debug_main
run_module(address, name, *extra, **kwargs)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_local.py", line 53, in run_module
run(argv, addr, **kwargs)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_local.py", line 125, in _run
_pydevd.main()
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_vendored\pydevd\pydevd.py", line 1752, in main
globals = debugger.run(setup['file'], None, None, is_module)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_vendored\pydevd\pydevd.py", line 1099, in run
return self._exec(is_module, entry_point_fn, module_name, file, globals, locals)
File "c:\Users\defau\.vscode\extensions\ms-python.python-2018.8.0\pythonFiles\experimental\ptvsd\ptvsd\_vendored\pydevd\pydevd.py", line 1123, in _exec
runpy._run_module_as_main(module_name, alter_argv=False)
File "c:\program files (x86)\microsoft visual studio\shared\python36_64\Lib\runpy.py", line 193, in _run_module_as_main
"__main__", mod_spec)
File "c:\program files (x86)\microsoft visual studio\shared\python36_64\Lib\runpy.py", line 85, in _run_code
exec(code, run_globals)
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\flask\__main__.py", line 14, in <module>
main(as_module=True)
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\flask\cli.py", line 894, in main
cli.main(args=args, prog_name=name)
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\flask\cli.py", line 548, in main
load_dotenv()
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\flask\cli.py", line 608, in load_dotenv
dotenv.load_dotenv(path)
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\dotenv\main.py", line 255, in load_dotenv
return DotEnv(f, verbose=verbose).set_as_environment_variables(override=override)
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\dotenv\main.py", line 95, in set_as_environment_variables
for k, v in self.dict().items():
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\dotenv\main.py", line 74, in dict
values = OrderedDict(self.parse())
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\dotenv\main.py", line 79, in parse
f = self._get_stream()
File "D:\DevNotes\ProjectFolder\.env\lib\site-packages\dotenv\main.py", line 62, in _get_stream
return io.open(self.dotenv_path)
PermissionError: [Errno 13] Permission denied: 'D:\\DevNotes\\ProjectFolder\\.env'

次は仮想環境ではない、ローカルのpipです。

$ pip freeze
astroid==2.0.4
Click==7.0
colorama==0.3.9
cycler==0.10.0
future==0.16.0
isort==4.3.4
itsdangerous==0.24
Jinja2==2.10
kiwisolver==1.0.1
lazy-object-proxy==1.3.1
MarkupSafe==1.0
matplotlib==3.0.0
mccabe==0.6.1
numpy==1.15.2
pefile==2018.8.8
pylint==2.1.1
pyparsing==2.2.1
pypiwin32==223
python-dateutil==2.7.3
pywin32==223
six==1.11.0
typed-ast==1.1.0
virtualenv==16.0.0
Werkzeug==0.14.1
wrapt==1.10.11
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

本題にお答えする前に、いろいろと外堀を埋めなければならないご質問です。

pip install python-dotenvを実施すると下記ソースコードでPermissionErrorが起きる。

pip installは独立したコマンドで、ソースの内容とは関係ありません。
実行すると、パッケージ(今回の場合はpython-dotenv)をダウンロードして、規定のディレクトリにインストールします。それにより、ソースコードの中からそのパッケージをimportしたり、そのパッケージが提供するコマンドを実行するといったことができるようになります。
このとき、規定のディレクトリに、pip installを実行したユーザーの書き込み権限がないと上記のエラーとなります。

対応方法は、利用中のPythonがどのように(どこに)インストールされたかによって変わります。


 追記

dotenvの利用法はご覧になってますか。
https://github.com/theskumar/python-dotenv
.envという名前のファイルを用意する必要があり、それを読み込んで情報取得するようです。

エラーのトレースを見ると、.envというフォルダを読み込もうとしてますが。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/10/07 21:50 編集

    こんばんは、ご回答&ご質問ありがとうございます!

    どこに、というのは仮想環境であるかどうかという理解であっているでしょうか?
    以下のもので外堀が埋まるでしょうか?
    もし違った場合、お手数かけてしまいますがどのような情報があればよいかご教示いただければ幸いです。

    マークダウンができなかったので質問の方に追記させて頂きました。

    キャンセル

  • 2018/10/08 15:07

    動きました!!
    リファレンスをしっかり読んでいませんでした…申し訳ないです。

    python-dotenvが動作する環境を作っていないことが原因でした。

    .env
    setting.py
    を作成&設定することでデバッグ実行することが出来て、view関数などから.envの内容を取得できることが確認できました!

    python-dotenvを利用する場合は.envというファイルは予約されているので使ってはいけないのですね…。

    そして、公開したくないものは.env、公開しても構わないものは.flaksenvといった使い分けがあったりするのですね…、使い道も大まかに分かった気になれました。

    本当に助かりました、ありがとうございました!

    キャンセル

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

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