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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

1回答

747閲覧

表面温度をCSVに出力したい

Chisui

総合スコア0

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2021/03/26 04:56

前提・実現したいこと

人物の顔に反応し表面温度を測るプログラムを作っているのですが、
取得した表面温度をCSVファイルに書き出したいです。

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

測定した温度がCSVファイルに出力されていません。(空のファイルです)

該当のソースコード

Python3

1import time 2import numpy as np 3import cv2 as cv 4 5import busio 6import board 7 8import adafruit_amg88xx 9 10i2c = busio.I2C(board.SCL, board.SDA) 11sensor = adafruit_amg88xx.AMG88XX(i2c, addr=0x68) 12 13time.sleep(0.2) 14 15# カメラ初期化 16cap = cv.VideoCapture(0) 17 18# 顔の分類器の作成 19faceCascade = cv.CascadeClassifier('haarcascades/haarcascade_frontalface_default.xml') 20 21while True: 22 ret, frame = cap.read() 23 h, w, c = frame.shape 24 25 # カメラの画像を半分にする 26 gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY) 27 28 # 顔の認識 29 facerect = faceCascade.detectMultiScale(gray, scaleFactor=1.2, minNeighbors=6, minSize=(1, 1)) 30 with open('data.csv','w') as f: 31 32 if len(facerect) > 0: 33 for rect in facerect: 34 # 配列のスライス→ rect[開始位置:終了位置] rect[0:2]→[左上X座標, 左上Y座標] 35 cv.rectangle(frame, tuple(rect[0:2]), tuple(rect[0:2]+rect[2:4]), (0, 0, 255), thickness=2) 36 37 max_temp = 0.0 38 # 8x8の温度配列 39 pixels = sensor.pixels 40 for x in range(len(pixels)): 41 for y in range(len(pixels[0])): 42 # 最大温度を格納する 43 if (pixels[x][y] > max_temp): 44 max_temp = pixels[x][y] 45 46 47 print('温度: '+str(max_temp)) 48 49 50 cv.imshow('camera capture', frame) 51 52 # ESC 53 if cv.waitKey(1) == 27: 54 break 55 56cap.release() 57# 表示したウィンドウを閉じる 58cv.destroyAllWindows()

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

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

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

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

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

ppaul

2021/03/26 07:19

ファイルにはどういうものが書き込まれていることを期待していますか?
guest

回答1

0

ファイルに書き込んでいないためです。
printを以下のようにfile指定する事で出力する事ができます。

python

1 print('温度: '+str(max_temp), file=f)

投稿2021/03/26 05:35

yamap55

総合スコア1376

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

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

Chisui

2021/03/31 03:43

返信が遅くなり申し訳ありません。 以下のとおりに試してみても解決しませんでした。以前と同様、空のCSVファイルです。 import time import numpy as np import cv2 as cv import busio import board import adafruit_amg88xx i2c = busio.I2C(board.SCL, board.SDA) sensor = adafruit_amg88xx.AMG88XX(i2c, addr=0x68) time.sleep(0.2) # カメラ初期化 cap = cv.VideoCapture(0) # 顔の分類器の作成 faceCascade = cv.CascadeClassifier('haarcascades/haarcascade_frontalface_default.xml') while True: ret, frame = cap.read() h, w, c = frame.shape # カメラの画像を半分にする gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY) # 顔の認識 facerect = faceCascade.detectMultiScale(gray, scaleFactor=1.2, minNeighbors=6, minSize=(1, 1)) s = 'data.csv' with open('path_w', mode='w') as f: f.write(s) with open('path_w') as f: print(f.read()) if len(facerect) > 0: for rect in facerect: # 配列のスライス→ rect[開始位置:終了位置] rect[0:2]→[左上X座標, 左上Y座標] cv.rectangle(frame, tuple(rect[0:2]), tuple(rect[0:2]+rect[2:4]), (0, 0, 255), thickness=2) max_temp = 0.0 # 8x8の温度配列 pixels = sensor.pixels for x in range(len(pixels)): for y in range(len(pixels[0])): # 最大温度を格納する if (pixels[x][y] > max_temp): max_temp = pixels[x][y] print('温度: '+str(max_temp), file=f) cv.imshow('camera capture', frame) # ESC if cv.waitKey(1) == 27: break cap.release() # 表示したウィンドウを閉じる cv.destroyAllWindows()
yamap55

2021/03/31 04:32

1. 質問文に追記してください。(インデントも注意) 2. ppaulさんから質問が来ている通り、何がファイルに出力されることを期待していますか? 3. 最初の質問とは異なりますがpath_wというファイルに'data.csv'という文字列を書き込んでいますがあっていますか? 4. コメントに記載して頂いたコードだとインデントがわからないので何ともですが、with句を抜けた後に書き込んでいませんか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問