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

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

ただいまの
回答率

90.48%

  • Python

    8646questions

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

  • Linux

    3913questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • Raspberry Pi

    852questions

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

起動時に.serviceで起動するpythonプログラムのエラーログや原因を取得したい

解決済

回答 3

投稿

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

morutemu

score 33

基本情報:
OS:raspbeian
プログラム:python

内容:
pythonプログラムを起動時に起動させたいのですが、どうやらうまく動作せず、尚且つ、.serviceによる起動だとバックグラウンドでターミナルが起動し実行されているようなので、どのようにエラーが出ているのかわからず困っております。
実は以前に同じ質問をしたのですが、エラーログの取得をして、どういったエラーが出ているのか確認してみてはどうですか?と、回答があったのですが、実際どのようにエラーを取得したらよいか分からず困っております。

https://teratail.com/questions/124911

ちなみにプログラムはダブルクリックで起動させると動いていますが、自動起動はしません。
ただし、pythonファイルのファイル名と場所はそのままに、中のプログラムを消して、別のプログラムを入れたところ自動起動するみたいでした。

ファイル場所:
pythonファイル場所:/opt/GarbageDayReminder/GarbageDayReminder.py
.serviceファイル場所:/etc/systemd/system/GarbageDayReminder.service

動作:
シンボリックを作成済み:sudo systemctl enable GarbageDayReminder.service

pythonプログラム:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

# +++ モジュール +++
from threading import Thread
import RPi.GPIO as GPIO
import datetime
import schedule
import pandas
import time
import csv
import os

# +++ 変数 +++
# リマインド時間
spc_time = "7:20"

# 確認時間
start_time = "00:00:00"
end_time = "08:30:00"

# +++ クラス +++
class GarbageDayReminder(object):
    # イニシャライズ
    def __init__(self):
        pass

    # 日付処理
    def date(self):
        # 変数
        FormatDay = "%Y/%m/%d "
        FormatTime = "%H:%M:%S"

        # 今日の日時を取得
        now = datetime.datetime.now()

        # 明日の日時を取得
        tmr = now + datetime.timedelta(days=1)

        # 1990-01-01対策の現在日付を追加
        date = now.strftime(FormatDay)

        # 今日、明日を振り分ける時間を作成
        start = datetime.datetime.strptime(date + start_time, FormatDay + FormatTime)
        end = datetime.datetime.strptime(date + end_time, FormatDay + FormatTime)

        # 今日、明日日付取得の分岐
        if start <= now <= end:
            # 今日日付の取得
            today = "{}/{}/{}".format(now.year, now.month, now.day)
            return today ,"today"
        else:    
            # 明日の日付を取得
            tommorow = "{}/{}/{}".format(tmr.year, tmr.month, tmr.day)
            return tommorow ,"tommorow"

    # csv処理
    def csv(self,date):
        # データが格納されている作業ディレクトリまでパス指定
        os.chdir("/opt/GarbageDayReminder")

        # csvファイルを読み込む
        df = pandas.read_csv("garbage_day.csv")

        # 何のゴミの日か取得
        garbage = df[df["日付"] == date]["ゴミ"].values[0]

        return garbage

    # リマインダー処理
    def reminder(self, now, garbage):
        # 辞書
        gb_dict = {"燃":"燃やすごみ",\
                     "不":"燃やさないごみ",\
                     "缶":"空き缶、スプレー缶、空きびん、廃蛍光管",\
                     "資":"プラスチック製容器梱包、ペットボトル",\
                     "紙":"紙類ごみ",\
                     "草":"せんてい枝、庭の草", \
                     "粗":"粗大ごみ"}

        # 今日、明日の切替
        if now == "today":
            now = "今日"
        elif now == "tommorow":
            now = "明日"
        else:
            return

        # リマインド
        if garbage in gb_dict:
            msg = "/opt/jtalk/jtalk.sh " + "ぽーーん!" + now + "は" + gb_dict[garbage] + "の日です"
            os.system(msg)
        else:
            msg = "/opt/jtalk/jtalk.sh " + "ぽーーん!" + now + "のごみの日はありません"
            os.system(msg)

    # 中間処理
    def intermediate(self):
        # 日付処理
        date, now = gdr.date()

        # csv処理
        garbage = gdr.csv(date)

        # リマインダー処理
        gdr.reminder(now, garbage)

    # 指定時間処理
    def specified_time(self):
        # 指定時間に中間処理を実行
        schedule.every().day.at(spc_time).do(gdr.intermediate)
        while True:
            schedule.run_pending()
            time.sleep(1)

    # チェック処理
    def button(self):
        GPIO.setmode(GPIO.BCM)

        #GPIO12pinを入力モードとし、pull up設定とします 
        GPIO.setup(12,GPIO.IN,pull_up_down=GPIO.PUD_UP)

        while True:
            GPIO.wait_for_edge(12, GPIO.FALLING)
            sw_counter = 0

            while True:
                sw_status = GPIO.input(12)
                if sw_status == 0:
                    sw_counter = sw_counter + 1
                    if sw_counter >= 30:
                        print("長押し")
                        gdr.intermediate()
                        break
                else:
                    print("短押し")
                    break

                time.sleep(0.01)

            print(sw_counter)

    # メイン処理
    def main(self):
        # 指定時間処理(マルチスレッド)
        t = Thread(target=gdr.specified_time)
        t.start()

        # デバッグ用
        #gdr.intermediate()

        # ボタン処理
        gdr.button()

# +++ 初期動作 +++
if __name__ == "__main__":
    # GarbageDayReminderクラスをインスタンス化して実行
    gdr = GarbageDayReminder()
    gdr.main()

.serviceファイル

[Unit]
Description = GarbageDayReminder

[Service]
ExecStart = /usr/bin/python /opt/GarbageDayReminder/GarbageDayReminder.py
Restart = always
Type = simple

[Install]
WantedBy = multi-user.target
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 3

+1

とりあえずこうしてみましょうか。

import traceback

if __name__ == "__main__":
    try:
        # GarbageDayReminderクラスをインスタンス化して実行
        gdr = GarbageDayReminder()
        gdr.main()
    except:
        with open("見やすくて権限の問題のないファイルを適当に指定してください", "w") as f:
            traceback.print_exc(file=f)

if __name__ == "__main__":以下までは無事到達していて、例外で落ちていることが前提です。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/05/09 20:21

    どうやら、そこにたどり着けていないようですね。
    起動時にファイルと開くような動作はしませんでした。

    キャンセル

  • 2018/05/09 20:24

    if __name__ == "__main__":
    try:
    # GarbageDayReminderクラスをインスタンス化して実行
    gdr = GarbageDayReminder()
    gdr.main()
    except:
    with open("/home/pi/a.txt", "w") as f:
    traceback.print_exc(file=f)
    このように入れてみました。

    キャンセル

  • 2018/05/11 08:21 編集

    yahoo知恵袋より、聞いた所
    /var/log/syslog
    にてエラーログが見れるということで、確認したところ
    scheduleのimportエラーでした。
    一応、pip install scheduleではインストールしてあるので、ローカルには落ちていますが、起動時に起動させようとすると起動しないようです。もし何かわかれば教えて下さい

    キャンセル

  • 2018/05/11 08:31

    今気づいたけど、なんでシェバンは/usr/bin/env pythonで.serviceは/usr/bin/pythonになってるんですか?

    キャンセル

  • 2018/05/11 10:04

    どちらも
    /usr/bin/env python
    に統一した方が良いですか?

    キャンセル

  • 2018/05/11 10:34

    とりあえず試してみるのは一つの手ですね。
    アタリだったら嬉しいですが、ダメなら両方の実行方法でsys.versionやsys.pathを吐いてみて、どんな違いがあるか観察してみましょうか。自動実行の方は(落ちる前に)ファイル先頭でimport sysして、ファイル出力でもするか、syslogに吐いても良いでしょう(できるらしいので)
    https://docs.python.jp/3/library/syslog.html

    キャンセル

  • 2018/05/11 12:19

    了解です。
    仕事終わったら試して見ます!

    キャンセル

  • 2018/05/11 20:15

    残念ながら…でした。
    ExecStart = /usr/bin/env python /opt/GarbageDayReminder/GarbageDayReminder.py
    と、入れましたが、
    同じようにimport scheduleのエラーでした。。
    無念。

    キャンセル

check解決した方法

0

sudo pip install schedule


↑が解決方法でした。

私が解決したわけでないですが以下が解決方法でした。
私の質問に付き合っていただけた方ありがとうございました!

https://teratail.com/questions/125792

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

もしかして、実行するpythonはpyenvなどを使って構築されてますか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/05/11 20:39

    いや、使ってないと思います。
    たぶん。

    キャンセル

  • 2018/05/12 09:45

    さすがです。それでした。
    また違う質問をして、ほかの人に答えていただいたのですが、それが原因のようです。
    https://teratail.com/questions/125361

    キャンセル

関連した質問

  • 解決済

    pythonのエラー

    testThreadが見つからないというメッセージが出てきたのですが、どこに問題があるのでしょうか? よろしくお願いします コード #-*- coding utf-8-*-

  • 受付中

    字下げについて

    お世話になります 本日マイナビ第26章を勉強しております http://news.mynavi.jp/series/python/026/ この中でどうしてもコマンドの字下げ

  • 解決済

    IndentationError: expected an indented block  原因はな...

    Raspberry Pi を使って人感センサーに反応したらiPhoneにお知らせする物を作りたいと思い、調べたところ下記のサイトを発見しました。 https://www.sho-

  • 解決済

    [Flask] ボタンでスレッドの開始と終了をコントロールさせる方法

     やりたいこと フォーム入力でなにかしらwebサービスのログイン情報を登録。 登録した情報の一覧画面で、アカウント情報の横にはボタンがあって、 開始ボタンを押したら何かしらの

  • 解決済

    python3 単語を出てきた順で数えたい

    単語の出てきた順に単語数をカウントしたいのですが、collectionsのCounterを使うと単語の多い順で表示される。かといってOrderedDictを使うと入力の読み取りをし

  • 解決済

    Pythonのthreadingにおける、終了時の処理

    前提・実現したいこと Pythonを使って、動画や画像を表示するGUIを作っています。その中で、みなさまのご支援を頂ながらカメラの画像を取り込んで再生できるところまで来ました。

  • 解決済

    pythonでログの分析(時間)が出来ません。

    前提・実現したいこと pythonのプログラムで質問です。 以下のログがあります。 2012/01/02 13:00 0 2012/01/02 14:00 1 2012/01/

  • 解決済

    センサーで感知すると天気予報を喋るプログラムの作り方

    前提・実現したいこと Raspberry piにセンサーを接続させて、天気予報を喋らせるというプログラムを実行したいのですがエラーがでて実行できませんでした。  センサーを接続させ

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

  • Python

    8646questions

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

  • Linux

    3913questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • Raspberry Pi

    852questions

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