進展があったのですが内容が変わってきたので別の質問として投稿させて頂きました。
Webアプリを作成してみたく、Flaskのチュートリアルを行ったときに掲題のエラーが発生しました。
前提・実現したいこと
Flaskチュートリアルを完了したい。
発生している問題・エラーメッセージ
PS D:\DevNotes\ProjectFolder.env> Scripts\Activate (.env) PS D:\DevNotes\ProjectFolder.env> $env:FLASK_APP = "flaskr" (.env) PS D:\DevNotes\ProjectFolder.env> $env:FLASK_ENV = "development" (.env) PS D:\DevNotes\ProjectFolder.env> flask run 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 "D:\DevNotes\ProjectFolder.env\Scripts\flask.exe\__main__.py", line 9, in <module> 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'
該当のソースコード
該当のものにあたるかはわかりませんが、現在のpyコードは以下のもののみです。
python
import os from flask import Flask def create_app(test_config=None): # create and configure the app app = Flask(__name__, instance_relative_config=True) app.config.from_mapping( SECRET_KEY='dev', DATABASE=os.path.join(app.instance_path, 'flaskr.sqlite'), ) if test_config is None: # load the instance config, if it exists, when not testing app.config.from_pyfile('config.py', silent=True) else: # load the test config if passed in app.config.from_mapping(test_config) # ensure the instance folder exists try: os.makedirs(app.instance_path) except OSError: pass # a simple page that says hello @app.route('/hello') def hello(): return 'Hello, World!' return app
試したこと
Start-Processでflask runを実行。
管理者権限でVSCode起動。
エラーで調べてみたのですが解決にいたれず・・・。
補足情報(FW/ツールのバージョンなど)
Windows10 Home
VisutlStudioCode
.envの環境
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.0
pylint 2.1.1
python-dotenv 0.9.1
setuptools 39.0.1
six 1.11.0
typed-ast 1.1.0
Werkzeug 0.14.1
wrapt 1.10.11
Webは知識がほぼなく情報が不足しているとは思いますがその場合はご指摘いただけると…。
何か理解の助けになることだけでもご教示頂ければ幸いです。
よろしくお願い致します。
【追記】
ご回答いただいた内容を次のように試してみましたが、エラーは変わりませんでした・・。
1.VSCodeのBashでパワーシェルを管理者で実行。
2.ifでパワーシェルが管理者権限であることを確認。
3..env環境に入る。(Scripts\Activate)
4.FLASK_APP,FLASK_ENV変数を宣言して、flask run を実行
仮想環境でなければ、Flask runは実行できました。(エラーは出ましたが)
.envで実行するため何かが足りていないのでしょうか…?
【追記2】
解決というわけではないのですが別のチュートリアルを試してみると.env環境でも動作しました。
アクセス権などを見直してみたり、調べたりしてみると一番解決へ近そうな回答をいただけたものを評価させていただきました。
Windowsでのpythonの権限関係がややこしいというのはいっぱいでてきたのでその辺が関係ありそうだなー・・・・。
まだ回答がついていません
会員登録して回答してみよう