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

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

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

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

Q&A

2回答

562閲覧

読み込んだ複数の画像ファイルを骨格推定をかけてから同じ名前で保存したい。

yu_ttot

総合スコア1

Python

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

0グッド

0クリップ

投稿2022/05/26 05:40

前提

tfpose-estimationを使用し骨格推定画像と骨格推定座標をjsonファイルで保存しようとしている。(jsonファイルについては問題なく保存できています)

実現したいこと

shファイル

1for i in `seq 1000 8925` 2do 3 4python3 run1.py --model mobilenet_thin --image=./sapoin_data/寝/No.10021/No_10021_a_00000000_$i.png --output_json=./sapoin_result/json/寝/No.10021/No_10021_a_00000000_$i.json 5 6done

を実行して複数の画像を同じ名前で保存したい。

発生している問題

画像保存はできているが更新しながら保存してしまっており複数枚(No_10021_a_00000000_1000.png , No_10021_a_00000000_1001.png...)の画像保存ができておらず1枚(No_10021_a_00000000_1000.png)だけ保存されている。

該当のソースコード

run1.py

1import argparse 2import logging 3import sys 4import time 5import glob 6import os 7 8from tf_pose import common 9import cv2 10import numpy as np 11from tf_pose.estimator import TfPoseEstimator 12from tf_pose.networks import get_graph_path, model_wh 13 14logger = logging.getLogger('TfPoseEstimatorRun') 15logger.handlers.clear() 16logger.setLevel(logging.DEBUG) 17ch = logging.StreamHandler() 18ch.setLevel(logging.DEBUG) 19formatter = logging.Formatter('[%(asctime)s] [%(name)s] [%(levelname)s] %(message)s') 20ch.setFormatter(formatter) 21logger.addHandler(ch) 22 23path_list = glob.glob('./sapoin_data/寝/No.10021/No_10021_a_00000000_*.png') 24result_list ='./sapoin_result/img/寝/No.10021/' 25 26if __name__ == '__main__': 27 parser = argparse.ArgumentParser(description='tf-pose-estimation run') 28 parser.add_argument('--image', type=str, default='./images/p1.png') 29 parser.add_argument('--image_dir', type=str,default=glob.glob('./images/*.png')) 30 parser.add_argument('--model', type=str, default='cmu', 31 help='cmu / mobilenet_thin / mobilenet_v2_large / mobilenet_v2_small') 32 parser.add_argument('--resize', type=str, default='0x0', 33 help='if provided, resize images before they are processed. ' 34 'default=0x0, Recommends : 432x368 or 656x368 or 1312x736 ') 35 parser.add_argument('--number_people_max', type=int, default=1, help='maximum number of people') 36 parser.add_argument('--resize-out-ratio', type=float, default=4.0, 37 help='if provided, resize heatmaps before they are post-processed. default=1.0') 38 parser.add_argument('--output_json', type=str, default='/tmp/', help='writing output json dir') 39 args = parser.parse_args() 40 41 w, h = model_wh(args.resize) 42 if w == 0 or h == 0: 43 e = TfPoseEstimator(get_graph_path(args.model), target_size=(432, 368)) 44 else: 45 e = TfPoseEstimator(get_graph_path(args.model), target_size=(w, h)) 46 47 # estimate human poses from a single image ! 48 image = cv2.imread(args.image, None) 49 for fname in path_list: 50 fname = os.path.basename(fname) 51 52 t = time.time() 53 humans = e.inference(image, resize_to_default=(w > 0 and h > 0),upsample_size=args.resize_out_ratio) 54 elapsed = time.time() - t 55 56 logger.info('inference image: %s in %.4f seconds.' % (args.image, elapsed)) 57 58 image = TfPoseEstimator.draw_humans(image, humans, imgcopy=False, frame=0, output_json_dir=args.output_json) 59 cv2.imwrite(f'./sapoin_result/img/寝/No.10021/{fname}.png', image) 60

プログラム初心者のため色々なサイトとを参考にしながらプログラムを改良したのですがうまくいかず困っています。
ヒントなどでもいいのでわかる方がいらっしゃいましたらご教授お願いいたします。

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

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

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

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

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

guest

回答2

0

後半ですが、

python

1 2 for fname in path_list: 3 fname = os.path.basename(fname) 4 5 t = time.time() 6 humans = e.inference(image, resize_to_default=(w > 0 and h > 0),upsample_size=args.resize_out_ratio) 7 elapsed = time.time() - t 8 9 logger.info('inference image: %s in %.4f seconds.' % (args.image, elapsed)) 10 11 image = TfPoseEstimator.draw_humans(image, humans, imgcopy=False, frame=0, output_json_dir=args.output_json) 12 cv2.imwrite(f'./sapoin_result/img/寝/No.10021/{fname}.png', image)

こうではなく

python

1 2 for fname in path_list: 3 fname = os.path.basename(fname) 4 5 t = time.time() 6 humans = e.inference(image, resize_to_default=(w > 0 and h > 0),upsample_size=args.resize_out_ratio) 7 elapsed = time.time() - t 8 9 logger.info('inference image: %s in %.4f seconds.' % (args.image, elapsed)) 10 11 image = TfPoseEstimator.draw_humans(image, humans, imgcopy=False, frame=0, output_json_dir=args.output_json) 12 cv2.imwrite(f'./sapoin_result/img/寝/No.10021/{fname}.png', image)

こうじゃないですか?
インデントがずれているので一回しか実行されていないんだと思います。

また、

python

1for fname in path_list: 2 fname = os.path.basename(fname)

ここですがfor文で取り出したものを書き換えるのはあまり推奨しないです。
fname=ではなく別の変数に入れるほうがいいと思います。

投稿2022/05/26 05:56

編集2022/05/26 06:00
irognodyci

総合スコア227

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

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

yu_ttot

2022/05/26 06:15

irognodyciさん>ご回答ありがとうございます。 インデントですがこちらの方は試してみたのですが結果は同じような結果になりました。 for fname in path_list: fname = os.path.basename(fname) の部位は他の回答者にもご指摘いただきました。今後プログラムを作成する際には気をつけたいと思います。
guest

0

処理の内容は全く見ていませんが、以下の場所はおかしいです。

png画像の保存は

python

1cv2.imwrite(f'./sapoin_result/img/寝/No.10021/{fname}.png', image)

で、ファイル名は、「frame」で定義されています。そのfnameは、

python

1 for fname in path_list: 2 fname = os.path.basename(fname)

で定義されていますが、この処理には問題が 2つあって、

  • このループの意味が不明
    path_listにあるファイルを順に入れてまわしているが単にまわしているだけなので、結果としてfnameには最後のパスでの結果しか入らない。
  • fnameでループしているのにそのfnameそのものを変更してしまっているので、処理がおかしい。

せめて、

python

1 for p in path_list: 2 fname = os.path.basename(p)

とすべきだけど、それでも最初の問題があるので無意味。

ということで、保存したファイル名がおかしい理由はこれです。

ただ、そこを直してもちゃんと処理できるようには思えないので、受け取とった引数でどのような処理をするのかを、改めて検討する必要があると思います。

投稿2022/05/26 05:53

TakaiY

総合スコア12765

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

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

yu_ttot

2022/05/26 06:11

TakaiYさん>ご回答ありがとうございます。 for p in path_list: fname = os.path.basename(fname) ですがはじめは fname = os.path.basename(path_list) としてプログラムを書いていたのですが、 Traceback (most recent call last): File "run1.py", line 49, in <module> fname = os.path.basename(path_list) File "/usr/lib/python3.6/posixpath.py", line 146, in basename p = os.fspath(p) TypeError: expected str, bytes or os.PathLike object, not list というようなエラーがでてしまい、listからファイルパスを1つずつ取り出そうとするためにこのように書かせていただいております。 改めて検討したいと思います。
TakaiY

2022/05/26 07:56

「listからファイルパスを1つずつ取り出そう」はいそこは合っているのですが、書いたように、回していても、そのときに単にfnameに入れることだけしかしていないので、意味の無い処理になっています。 また、ループの変数fnameをそのまま書き換えているところもだめです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問