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

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

新規登録して質問してみよう
ただいま回答率
85.46%
Raspberry Pi

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

Python

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

Q&A

解決済

1回答

1419閲覧

rc.localでpythonコードを起動できない

sunstar

総合スコア1

Raspberry Pi

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

Python

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

0グッド

0クリップ

投稿2021/12/28 17:34

編集2021/12/29 01:44

ラズベリーパイのrc.localでpythonの自動実行を試しているのですがなかなか上手く行きません。

やりたいことは、アクセスポイント化したラズパイが外部端末から受け取ったmqttデータをsqlite3に保存するプログラムをラズパイの起動に合わせて自動で実行するといった内容です。

使用機器 ラズパイ3b+

rc.localの設定内容とpythonのスクリプトを掲載しておきます。

よろしくおねがいします。

rc.localの設定

service mosquitto stop service dhcpcd stop service hostapd stop service dnsmasq stop sleep 8 service dnsmasq start service hostapd start service dhcpcd start service mosquitto start sleep 10 python main3.py

pythonのスクリプト

import paho.mqtt.client as mqtt import sqlite3 import datetime MQTT_HOST = 'ラズパイのアドレス' MQTT_PORT = ポート番号 MQTT_CLIENT_ID = '任意のID' MQTT_USER = 'ユーザー名' MQTT_PASSWORD = 'パスワード' TOPIC = 'トピック' DATABASE_FILE = 'データベースファイルのパス' def on_connect(mqtt_client, user_data, flags, conn_result): mqtt_client.subscribe(TOPIC) def on_message(mqtt_client, user_data, message): payload = message.payload.decode('utf-8') db_conn = user_data['db_conn'] sql = 'INSERT INTO sensors_data (topic, payload, created_at) VALUES (?, ?, ?)' cursor = db_conn.cursor() cursor.execute(sql, (message.topic, payload, datetime.datetime.now())) db_conn.commit() cursor.close() def main(): db_conn = sqlite3.connect(DATABASE_FILE) sql = """ CREATE TABLE IF NOT EXISTS sensors_data ( id INTEGER PRIMARY KEY AUTOINCREMENT, topic TEXT NOT NULL, payload TEXT NOT NULL, created_at INTEGER NOT NULL ) """ cursor = db_conn.cursor() cursor.execute(sql) cursor.close() mqtt_client = mqtt.Client(MQTT_CLIENT_ID) mqtt_client.username_pw_set(MQTT_USER, MQTT_PASSWORD) mqtt_client.user_data_set({'db_conn': db_conn}) mqtt_client.on_connect = on_connect mqtt_client.on_message = on_message mqtt_client.connect(MQTT_HOST, MQTT_PORT) mqtt_client.loop_forever() main()

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

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

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

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

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

melian

2021/12/29 02:05

python main3.py としていますが、main3.py を絶対パスに置き換えるとどうなるでしょうか?
sunstar

2021/12/29 02:16

今回はhomeディレクトリにある為 /home/pi/main3.py と設定してみましたが起動しませんでした。
otn

2021/12/29 03:25

> なかなか上手く行きません。 具体的な問題点は何ですか? 「こういう結果を期待してるが、実際の結果はこれこれである」という風に書きましょう。
guest

回答1

0

自己解決

質問させていただきましたが、なんとか自分で解決することができました。
返答していただけた方には本当に申し訳ありません。
以下に解決した際のコードを載せさせていただきます。

service mosquitto stop service dhcpcd stop service hostapd stop service dnsmasq stop sleep 8 service dnsmasq start service hostapd start service dhcpcd start service mosquitto start sleep 10 sudo usr/bin/python /home/pi/main3.py

投稿2022/01/05 07:09

sunstar

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問