🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

Python

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

Q&A

解決済

1回答

2779閲覧

Pythonのテンプレートマッチングのプログラムコードをループ化したい

study5563

総合スコア9

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

Python

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

0グッド

0クリップ

投稿2019/11/11 05:44

編集2019/11/11 11:58

前提・実現したいこと

Pythonのテンプレートマッチングのプラグラムコードをループ化して簡略化したいと思っております。camera.jpgと1.jpgから8.jpgまでの画像をそれぞれテンプレートマッチングさせるコードになります。temp1 = cv2.imread("1.jpg")の部分からmatch_val[8] = max_valueの部分までを、1から8までいちいちコードを書くと長いのでループ化して短縮したいと思っているのですが初心者なもので書き方がよく分かりません。お願いいたします。

該当のソースコード

import cv2 import numpy as np """ select_point関数(変換元画像の座標選択) """ def select_point(event, x, y, flags, param): if event == cv2.EVENT_FLAG_LBUTTON: cv2.circle(img, (x,y), 3, (255,0,0), -1) points.append(x) points.append(y) print(points) print() """ グローバル変数など """ img = cv2.imread('camera.jpg') rows, cols, ch = img.shape points = [] cv2.namedWindow('input') cv2.setMouseCallback('input', select_point) """ マウス操作(4点を選択) """ while(1): cv2.imshow('input',img) if cv2.waitKey(1) & 0xFF == 27: break """ ホモグラフィ変換 """ pts1 = np.float32([[points[0],points[1]],[points[2],points[3]],[points[4],points[5]],[points[6],points[7]]]) pts2 = np.float32([[200,10],[620,10],[620,430],[200,430]]) # 変換行列の作成 M = cv2.getPerspectiveTransform(pts1, pts2) # 画像の変換 dst = cv2.warpPerspective(img, M, (800, 600)) # 変換結果の表示 cv2.imshow('perspective',dst) cv2.imwrite("image.jpg", dst) """ """ match_val = {} img = dst[40:223, 8:138] cv2.imwrite("image.jpg",img) temp1 = cv2.imread("1.jpg") temp2 = cv2.imread("2.jpg") temp3 = cv2.imread("3.jpg") temp4 = cv2.imread("4.jpg") temp5 = cv2.imread("5.jpg") temp6 = cv2.imread("6.jpg") temp7 = cv2.imread("7.jpg") temp8 = cv2.imread("8.jpg") # グレースケール変換 gray = cv2.cvtColor(img, cv2.COLOR_RGB2GRAY) temp1 = cv2.cvtColor(temp1, cv2.COLOR_RGB2GRAY) temp2 = cv2.cvtColor(temp2, cv2.COLOR_RGB2GRAY) temp3 = cv2.cvtColor(temp3, cv2.COLOR_RGB2GRAY) temp4 = cv2.cvtColor(temp4, cv2.COLOR_RGB2GRAY) temp5 = cv2.cvtColor(temp5, cv2.COLOR_RGB2GRAY) temp6 = cv2.cvtColor(temp6, cv2.COLOR_RGB2GRAY) temp7 = cv2.cvtColor(temp7, cv2.COLOR_RGB2GRAY) temp8 = cv2.cvtColor(temp8, cv2.COLOR_RGB2GRAY) # テンプレート画像の高さ・幅 h, w = temp1.shape # テンプレートマッチング(OpenCVで実装) match = cv2.matchTemplate(gray, temp1, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[1] = max_value # テンプレート画像1を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp2, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[2] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp3, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[3] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp4, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[4] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp5, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[5] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp6, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[6] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp7, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[7] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 match = cv2.matchTemplate(gray, temp8, cv2.TM_CCOEFF_NORMED) min_value, max_value, min_pt, max_pt = cv2.minMaxLoc(match) pt = max_pt print(min_value, max_value, min_pt, max_pt) match_val[8] = max_value # テンプレート画像2を使ってテンプレートマッチングしたときの類似度の最大値を保存 # 類似度が一番大きいときのキーの値を出力する。 max_no = max(match_val, key=match_val.get) print() print(f"{max_no}です") cv2.waitKey(0) cv2.destroyAllWindows()

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

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

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

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

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

guest

回答1

0

ベストアンサー

python

1from glob import glob 2imagelist = glob("*.jpg") 3

上記でカレントディレクトリ内の「.jpg」で終わるファイル名のリストが取得できますので、そのリストをforループで回すと良いと思います。
ファイル名が必ず「数字一桁.jpg」であれば
imagelist = glob("[0-9].jpg")
という書き方もできます。

投稿2019/11/15 08:50

AkiFuku

総合スコア129

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問