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

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

ただいまの
回答率

90.36%

  • Python 2.7

    1333questions

    Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

  • Raspberry Pi

    888questions

    Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

raspberryの電源投入時にPyAudioで録音開始したい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 229

inte_m

score 1

 前提・実現したいこと

§実現したいこと
PyAudioで録音し、有る周波数の音量がある周期で設定値を超えたら、wavファイルを保存するプログラムをラズパイ起動時に実行させたい。

§前提
ラズパイのバージョンはラズパイ3Bで
No LSB modules are available.
Distributor ID:    Raspbian
Description:    Raspbian GNU/Linux 9.4 (stretch)
Release:    9.4
Codename:    stretch
Linux pi3 4.14.34-v7+ #1110 SMP Mon Apr 16 15:18:51 BST 2018 armv7l GNU/Linux
です。
USBサウンドデバイスを使ってアナログマイクより集音しています。
apache2のサーバーで、三つのマルチプロセスが起動しています。

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

LXterminalで「python /home/pi/autorecord.py」を入力すると録音できる。
が自動起動では、起動できなかったり、起動しても録音しない。
エラーメッセージはない。

 該当のソースコード

python2.7
ソースコード

PyAudioで録音しmultiprocessingでデータの取り出しとFFTでlowpass後、判定処理、fastenersでファイル読み書きの排他制御をしています。

 試したこと

ps ax コマンドで起動中か以下の自動起動を確認
①/etc/rc.local
sleep 20
python /home/pi/autorecord.py &
または
sleep 20
python /home/pi/autorecord.py
で起動しない
②crontab
@reboot /home/pi/autorecord.sh
起動はされるが録音しない
③autostart
@/home/pi/autorecord.sh
起動されない
④systemd を使う方法
起動はされるが録音しない

 補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+1

まず、なぜ起動しないのか原因をしっかり確認しないと、なにをやっても起動しないってことになるぞ。

おそらく、あなたのコードが起動されるんだけど何らかの原因で異常終了されるだけだと思うけど


ログファイルを書き出すようにして、果たして起動されたのか、されなかったのか、どこまで動いたのかなどをログで残すべし。
起動されたけど録音されないってのは明らかにコードにバグが有るってことだから、そのプログラムに問題があるってのは明らかでしょ

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/07 10:17

    loggingするようにしたら、print文で戻っていることがわかりました。ありがとうございました。

    キャンセル

0

now = datetime.datetime.now()
logging.debug(u'音を検知')
print(now.strftime('%Y_%m_%d %H:%M:%S')+u'に音を検知しました')
logging.debug(u'前回までの音回数を取得')
というふうに、ログをはくようにしたところ「前回までの音回数を取得」のログが出力されないで、
「音を検知」のログまでしかログに出力されていませんでした。

また
now = datetime.datetime.now()
logging.debug(u'音を検知')
print(u'音を検知しました')
logging.debug(u'前回までの音回数を取得')
としても「前回までの音回数を取得」のログが出なかったので「print(u'音を検知しました')」を
コメントアウトしたところ、正常に動作しました

自動起動はcrontab -eで
@reboot /home/pi/autorecord.sh

autorecord.shは

!/bin/sh

sleep 40
python /home/pi/autorecord.py &
としました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Python 2.7

    1333questions

    Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

  • Raspberry Pi

    888questions

    Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。