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

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

ただいまの
回答率

89.89%

flask jinja2 pipenv環境でTempateNotFoundが解消できない

解決済

回答 1

投稿 編集

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

rie_

score 6

既存のアプリケーションに、一つのHTML'aboutapp/info.html'を追加しました。
Wiondows環境では'aboutapp/info.html'が表示され問題ありません。
Templateの位置や、呼び出し方に問題はないと思います。

このをソースをUnix環境にアップすると、追加したHTMLのみTempateNotFoundが発生します。
pipenvが影響しているのでしょうか。

\app\init.py

    # views/auth.py
    from .views import auth
    app.register_blueprint(auth.bp, url_prefix=url_prefix_str)

    # views/auth.py
    from .views import aboutapp
    app.register_blueprint(aboutapp.bp, url_prefix=url_prefix_str)

\app\views\auth.py
\app\views\aboutapp.py

bp = Blueprint('aboutapp', __name__)  # Blueprint登録

@bp.route('/info')
@login_required
def info():
    """ APP情報画面を表示する """
    if request.method == 'GET':
        # APP情報画面初期表示
        return render_template('aboutapp/info.html')

\app\templates\auth\login.html
\app\templates\aboutapp\info.html

新しいディレクトリ(\app\templates\aboutapp\)と
その他の更新したファイル(init.py、aboutapp.py、aboutapp\info.html)が
アップされていることは確認しています。

エラー

[2020/01/15 13:46:23] ERROR - app.py#log_exception:1891: Exception on /test/aboutapp/info [GET]
Traceback (most recent call last):
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/app.py", line 2446, in wsgi_app
response = self.full_dispatch_request()
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/app.py", line 1951, in full_dispatch_request
rv = self.handle_user_exception(e)
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask_cors/extension.py", line 161, in wrapped_function
return cors_after_request(app.make_response(f(*args, kwargs))) File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/app.py", line 1820, in handle_user_exception reraise(exc_type, exc_value, tb) File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/_compat.py", line 39, in reraise raise value File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/app.py", line 1949, in full_dispatch_request rv = self.dispatch_request() File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/app.py", line 1935, in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) File "/home/test/test-app/app/views/auth.py", line 142, in wrapped_view return view(kwargs)
File "/home/test/test-app/app/views/aboutapp.py", line 19, in info
return render_template('aboutapp/info.html', **locals())
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/templating.py", line 138, in render_template
ctx.app.jinja_env.get_or_select_template(template_name_or_list),
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/jinja2/environment.py", line 869, in get_or_select_template
return self.get_template(template_name_or_list, parent, globals)
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/jinja2/environment.py", line 830, in get_template
return self._load_template(name, self.make_globals(globals))
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/jinja2/environment.py", line 804, in _load_template
template = self.loader.load(self, name, globals)
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/jinja2/loaders.py", line 113, in load
source, filename, uptodate = self.get_source(environment, name)
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/templating.py", line 60, in get_source
return self._get_source_fast(environment, template)
File "/home/test/.local/share/virtualenvs/test-app-C_4gkQLO/lib/python3.7/site-packages/flask/templating.py", line 89, in _get_source_fast
raise TemplateNotFound(template)
jinja2.exceptions.TemplateNotFound: aboutapp/info.html

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • rie_

    2020/01/16 08:50

    ありがとうございます。

    初期化について教えていただいたサイトでまた理解しておきます。

    # test が必要?
    # WorkingDirectory=/home/test/test-app
    →これは、UNIXのApachにほかのアプリが上がっているのでユーザで分けて、一つ階層をかませています。
    url_prefix_str = '/test'

    # views/about.py
    from .views import about
    app.register_blueprint(about.bp,
    url_prefix=url_prefix_str + '/about')

    キャンセル

  • rie_

    2020/01/16 08:51

    大文字は使っておらず、何か文字列に設定ミスがあるのかと、

    aboutapp/info → about/info にすべて置き換えてみました。

    するとうまくUNIXでも動きました。
    結果として、何かどこかでミスがあったのかもしれません。。

    皆さんのヒントのおかげで解消することができました。
    ありがとうございました。

    キャンセル

  • nico25

    2020/01/16 10:39

    そう言っていただけると助かります。
    迷宮入りしなくてよかったです :)

    キャンセル

回答 1

check解決した方法

0

すべて小文字ではありましたが、何か文字列に設定ミスがあるのかと、

aboutapp/info → about/info にすべて置き換えてみました。

するとうまくUNIXでも動きました。
結果として、修正している中でも自分では見つけられませんでしたが、
何かどこかでミスがあったのかもしれません。。

皆さんのヒントのおかげで解消することができました。
ありがとうございました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

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