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

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

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

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Python

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

Q&A

1回答

2729閲覧

pythonとflaskで書いたものをデプロイしたあとに画像を開きたい

退会済みユーザー

退会済みユーザー

総合スコア0

Flask

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Python

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

0グッド

0クリップ

投稿2020/04/26 06:25

モザイクアートを作るプログラムを
PythonとFlaskでつくり、Herokuでデプロイしました.
ローカル環境では、
(変数名:Target)
Target.show()

でフォトが開いていたのですが、
デプロイするとできません.
代わりにどうすればよいのでしょうか.

Python

1from flask import Flask, render_template, request 2from PIL import Image,ImageFilter 3import subprocess 4import os 5import random 6import math 7import time 8import numpy as np 9import glob 10import cv2 11 12app = Flask(__name__) 13 14# getのときの処理 15@app.route('/', methods=['GET']) 16def get(): 17 return render_template('index.html', \ 18 title = 'モザイクアートを作ろう', \ 19 message = '設定してください') 20 21# postのときの処理 22@app.route('/', methods=['POST']) 23def post(): 24 SourceDir = request.form['source'] 25 GoalImage = request.form["goal"] 26 OutputImage="output.jpg" 27 SourceImageSize=(60,40) 28 29 TargetZoom=11 30 31 used_count = 3 32 33 34 def __create_tile(org_image,height,width): 35 36 w, h = org_image.size 37 RectList=[] 38 for y in range(0, math.floor(h / height) + 1): 39 for x in range(0, math.floor(w / width) + 1): 40 height2 = y * height 41 width2 = x * width 42 crap_img = org_image.crop((width2, height2, width2 + width, height2 + height)) 43 RectList.append((crap_img,width2,height2)) 44 return RectList 45 46 def __clac_hist(img): 47 48 hist_list = [] 49 color = ['r','g','b'] 50 images = np.asarray(img) 51 52 for i in enumerate(color): 53 hist_list.append(cv2.calcHist([images],[i[0]],None,[256],[0,256])) 54 return hist_list 55 56 if __name__=="__main__": 57 58 startTime=time.time() 59 60 61 target=Image.open(GoalImage) 62 target=target.resize(tuple(math.floor(i*TargetZoom) for i in target.size)) 63 64 65 tiles = __create_tile(target,SourceImageSize[1],SourceImageSize[0]) 66 67 file_paths = glob.glob(SourceDir+"\*") 68 src_hist_dict = {} 69 for file_path in file_paths: 70 file_name = file_path.split("\")[-1] 71 72 try: 73 src_image = Image.open(file_path).resize(SourceImageSize) 74 except Exception: 75 continue 76 src_hist_dict[file_name] = [src_image,__clac_hist(src_image),0] 77 78 79 Target=Image.new("RGB",target.size,255) 80 print("モザイクアート生成開始") 81 while(len(tiles) > 0): 82 result = [] 83 84 r=random.randrange(len(tiles)) 85 tileRect=tiles[r] 86 del tiles[r] 87 88 tile_hist = __clac_hist(tileRect[0]) 89 90 tile_hist = np.array(tile_hist) 91 tile_hist = tile_hist.reshape(tile_hist.shape[0] * tile_hist.shape[1], 1) 92 93 94 for file_name,src_hist in src_hist_dict.items(): 95 src_hist = np.array(src_hist[1]) 96 src_hist = src_hist.reshape(src_hist.shape[0] * src_hist.shape[1], 1) 97 98 d = cv2.compareHist(tile_hist, src_hist, cv2.HISTCMP_INTERSECT) 99 result.append([d,file_name]) 100 result.sort(reverse=True) 101 102 Target.paste(src_hist_dict[result[0][1]][0],(tileRect[1],tileRect[2])) 103 104 src_hist_dict[result[0][1]][2] = src_hist_dict[result[0][1]][2] + 1 105 106 107 Target.show() 108 Target.save(OutputImage) 109 return render_template("index.html",message="モザイクアート生成完了", abcde=GoalImage) 110 111 112if __name__=="__main__": 113 app.run(debug=True) 114

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

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

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

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

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

guest

回答1

0

Target.show() は動作している PC 上で画像を表示しているので,Heroku に上げれば Heroku 上で開こうとするようなものです.実際にはアクセスしたスマホやパソコン上で開きたいので,画像が表示されないことになります.

ウェブサイトで画像を表示したい場合は,作成した画像を一度保存し,それを表示するような仕組みが考えられます.Heroku は原則として作成したファイル等を保存することができませんが,数分で消える一時ファイルであれば保存することができます.保存先ディレクトリは /tmp です.

Python

1def __clac_hist(img): 2 3 ... 4 5 OutputImage = '/tmp/output.jpg' 6 Target.save(OutputImage) 7return render_template(..., image_url=OutputImage)

例えば,上記のような処理をして index.html で <img src={{ image_url }} /> とするなどを試してみてはいかがでしょうか.

(追記)

tmpディレクトリを使用するためにルーティング設定が必要なようです.

Python

1from flask import Flask, render_template, request, send_from_directory 2 3... 4 5@app.route('/tmp/<path:filename>') 6def send_file(filename): 7 return send_from_directory('tmp', filename)

参考
https://stackoverflow.com/questions/48107708/how-do-i-load-image-in-python-flask
https://flask.palletsprojects.com/en/1.1.x/api/#flask.send_from_directory

投稿2020/05/01 14:51

編集2020/05/10 08:12
mktia

総合スコア110

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

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

退会済みユーザー

退会済みユーザー

2020/05/02 13:24

python: def __clac_hist(img): hist_list = [] color = ['r','g','b'] images = np.asarray(img) for i in enumerate(color): hist_list.append(cv2.calcHist([images],[i[0]],None,[256],[0,256])) OutputImage = '/tmp/output.jpg' Target.save(OutputImage) return hist_list return render_template("index.html", message="モザイクアートの生成完了", image_url=OutputImage) index.html: <!DOCTYPE html> <html lang="jn" dir="ltr"> <head> <meta charset="utf-8"> <title>モザイクアート生成サイト</title> </head> <body> <h1>{{ title }}</h1> <p>{{ message }}</p> <form action="/" method="POST" enctype="multipart/form-data"> <div> <label for="name">素材の入ったフォルダ:</label> <input type="text" id="source" name="source" placeholder="C:xxxx"> </div> <div> <label for="name">目標画像:</label> <input type="text" id="goal" name="goal" placeholder="C:xxxx"> </div> <div> <input type="submit" value="モザイクアート生成"> </div> <div> <img src={{ image_url }} /> <div> </form> </body> </html> このようにしたのですが、画像が表示されません。なぜでしょうか?
mktia

2020/05/02 13:50

正確には <img src="{{ image_url }}" /> でした. 実行した際にはブラウザのデベロッパーモードを使用して image_url が出力できていること,画像が保存されていることを確認してみてください.
退会済みユーザー

退会済みユーザー

2020/05/02 14:03

修正し、デベロッパーモードで確認すると output.jpgは出力されていましたが not found になっていました。 何度もすみません。
mktia

2020/05/02 14:09

not foundということは保存がうまくいっていないようです. OutputImage = './tmp/output.jpg' とするとどうなりますか?
退会済みユーザー

退会済みユーザー

2020/05/03 07:25

同様に、Not Found The requested URL was not found on the server. If you entered the URL manually please check your spelling and try again. と出てしまいました。
mktia

2020/05/03 07:38

Herokuのログには何か出ていますか?
退会済みユーザー

退会済みユーザー

2020/05/03 07:45

debug モードをオンにすると、 FileNotFoundError: [Errno 2] No such file or directory: './tmp/output.jpg' というエラーが出ていました。
mktia

2020/05/03 08:47

堂々巡りのようになってしまって申し訳ないですが、ファイルの呼び出しがうまくいっていないのか(パスが違うなど)、もしくは保存が成功していないのかを確認できればと思っています。 https://dashboard.heroku.com/apps/アプリ名/logs で確認できるログをみたときに、print('モザイクアート生成開始') が表示され、その後に Target.save() が動いたときにエラーが発生していれば保存が失敗しており、通っていれば保存はおそらく成功しているので呼び出し方が違う可能性があります。 実行したときにHerokuのダッシュボードでログを確認して save が動いているかどうか確認してみてください。
退会済みユーザー

退会済みユーザー

2020/05/03 10:50

Target.save()にエラーは出ていませんでした。 画像の呼び出しなどを調べたいと思います。
退会済みユーザー

退会済みユーザー

2020/05/08 03:37 編集

すみません。書き直したりしていると saveにエラーが出るようになりました。 ファイル名はoutput.jpgのはずだと思うのですが、 違うのでしょうか。
mktia

2020/05/08 09:53

OutputImage = "./tmp/output.jpg" としていれば、ファイル名は output.jpg として example.herokuapp.com/tmp 以下に保存されるものだと見ています。 保存時のエラーとは何でしょうか? 参考https://pillow.readthedocs.io/en/stable/reference/Image.html#PIL.Image.Image.save
退会済みユーザー

退会済みユーザー

2020/05/10 01:50

Target.saveに FileNotFoundError: [Errno 2] No such file or directory: './tmp/output.jpg' というエラーが出ています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問