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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

2回答

5606閲覧

ImportError: cannot import name 'Markup' from 'jinja2' の解決

tashiyama

総合スコア0

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/06/02 05:30

編集2022/06/02 07:20

前提

python初学者なのですがlinebotを作ってみたいと思い
送ったメッセージをそのまま返信するlinebotを作っています

実現したいこと

ImportError: cannot import name 'Markup' from 'jinja2' を解決して
ボットサーバーにHTTPステータスコード200を返したい
現状は(503 Service Unavailable)が返る

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

2022-06-01T01:11:50.368255+00:00 app[web.1]: Traceback (most recent call last): 2022-06-01T08:04:50.210242+00:00 app[web.1]: ImportError: cannot import name 'Markup' from 'jinja2' (/app/.heroku/python/lib/python3.10/site-packages/jinja2/__init__.py) 2022-06-01T08:04:50.379791+00:00 heroku[web.1]: Process exited with status 1 2022-06-01T08:04:50.428603+00:00 heroku[web.1]: State changed from starting to crashed 2022-06-01T08:05:13.474191+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=POST path="/"dyno= connect= service= status=503 bytes= protocol=https

該当のソースコード

main.py

1 2from flask import Flask, request, abort 3 4from linebot import ( 5 LineBotApi, WebhookHandler 6) 7from linebot.exceptions import ( 8 InvalidSignatureError 9) 10from linebot.models import ( 11 MessageEvent, TextMessage, TextSendMessage, 12) 13import os 14from jinja2 import Markup 15 16app = Flask(__name__) 17 18#環境変数取得 19YOUR_CHANNEL_ACCESS_TOKEN = os.environ["YOUR_CHANNEL_ACCESS_TOKEN"] 20YOUR_CHANNEL_SECRET = os.environ["YOUR_CHANNEL_SECRET"] 21 22line_bot_api = LineBotApi(YOUR_CHANNEL_ACCESS_TOKEN) 23handler = WebhookHandler(YOUR_CHANNEL_SECRET) 24 25@app.route("/yoshinani", methods=['POST']) 26def yoshinani(): 27 # get X-Line-Signature header value 28 signature = request.headers['X-Line-Signature'] 29 30 # get request body as text 31 body = request.get_data(as_text=True) 32 app.logger.info("Request body: " + body) 33 34 # handle webhook body 35 try: 36 handler.handle(body, signature) 37 except InvalidSignatureError: 38 abort(400) 39 40 return 'OK' 41 42 43@handler.add(MessageEvent, message=TextMessage) 44def handle_message(event): 45 line_bot_api.reply_message( 46 event.reply_token, 47 TextSendMessage(text=event.message.text)) 48 49 50if __name__ == "__main__": 51# app.run() 52 port = int(os.getenv("PORT", 5000)) 53 app.run(host="0.0.0.0", port=port)

試したこと

error

1 ImportError: cannot import name 'Markup' from 'jinja2'

ImportErrorが出ていたので

main.py

1from jinja2 import Markup

を追記して再度試みるも同じエラー文が返ってきた

補足情報

https://qiita.com/kro/items/67f7510b36945eb9689b
こちらの記事を参考にし追っかけながら作っています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

FiroProchainezo

2022/06/02 05:58

実際に動作させてエラーになったのは`from jinja2 import Markup`が無いソースコードということですか?
quickquip

2022/06/02 06:14

ImportError: cannot import name 'Markup' from 'jinja2' の時のTracebackを載せてください。(そうしないなら自分で読まないと)
tashiyama

2022/06/02 07:18

>>FiroProchainezoさん はい!ないソースコードでエラーが起きました >>quickquipさん Traceback、追記しました! ご指摘ありがとうございます!
guest

回答2

0

エラーは、jinja2がインストールされていないか、jinja2にMarkupが無いかあたりでしょうね。

ちょっと調べると、jinja2 3.1.0 で jinja2.Makupが削除されているようなので、参照している記事とのjinja2のバージョン違いなんじゃないでしょうか。

jinja2のバージョンを合せるか、「Markup and escape should be imported from MarkupSafe.」ということですね。

投稿2022/06/02 05:55

編集2022/06/02 06:00
TakaiY

総合スコア12765

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

私もまさに今同じ記事を読みながら同じ場所で躓いています。今requirements.txtの中身を以下に書き換えて試してみました。

jinja2==2.10
Flask==0.12.2
line-bot-sdk==1.5.0

上記の状態から再度deployを試みた所、エラー内容が変わりました。

2022-07-22T02:53:32.309957+00:00 heroku[web.1]: State changed from crashed to starting
2022-07-22T02:53:33.659155+00:00 heroku[web.1]: Starting process with command python main.py
2022-07-22T02:53:34.697653+00:00 heroku[web.1]: Process exited with status 1
2022-07-22T02:53:34.743959+00:00 heroku[web.1]: State changed from starting to crashed
2022-07-22T02:53:34.538302+00:00 app[web.1]: Traceback (most recent call last):
2022-07-22T02:53:34.538318+00:00 app[web.1]: File "/app/main.py", line 1, in <module>
2022-07-22T02:53:34.538418+00:00 app[web.1]: from flask import Flask, request, abort
2022-07-22T02:53:34.538429+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.10/site-packages/flask/init.py", line 19, in <module>
2022-07-22T02:53:34.538585+00:00 app[web.1]: from jinja2 import Markup, escape
2022-07-22T02:53:34.538594+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.10/site-packages/jinja2/init.py", line 33, in <module>
2022-07-22T02:53:34.538690+00:00 app[web.1]: from jinja2.environment import Environment, Template
2022-07-22T02:53:34.538702+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.10/site-packages/jinja2/environment.py", line 15, in <module>
2022-07-22T02:53:34.538807+00:00 app[web.1]: from jinja2 import nodes
2022-07-22T02:53:34.538816+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.10/site-packages/jinja2/nodes.py", line 19, in <module>
2022-07-22T02:53:34.538903+00:00 app[web.1]: from jinja2.utils import Markup
2022-07-22T02:53:34.538913+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.10/site-packages/jinja2/utils.py", line 647, in <module>
2022-07-22T02:53:34.539142+00:00 app[web.1]: from markupsafe import Markup, escape, soft_unicode
2022-07-22T02:53:34.539166+00:00 app[web.1]: ImportError: cannot import name 'soft_unicode' from 'markupsafe' (/app/.heroku/python/lib/python3.10/site-packages/markupsafe/init.py)

取り合えず、requirementsに追記することで当時のQiitaの記事が出た当時のJinja2にデグレードすることに成功はしたようです。とすると次は今回引っかかっているmarkupsafeをダウングレードしていけば成立はしそうです。

いずれにせよ、一旦デグレードで進めてみて完了次第で最新の状態のPythonライブラリで動くように(2022年版として)修正すべきかもしれませんね。

このまま進めてみますので進展ありましたら追記します。

追記
上の回答でjinja2のversionを合わせる方向で進めていましたが、単に「flaskのversionを最新にする」で成立しました。それで今回のerrorは解消されます。

投稿2022/07/22 02:58

編集2022/07/23 16:34
ClubYGT

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問