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

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

ただいまの
回答率

87.91%

時刻を記録・保存したいのですが、時刻が更新されずにずっと記録されて困っています。

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 1,196

score 16

前提・実現したいこと

人感センサで人を検知したらLEDを光らせ、その時刻を.txtで記録、保存したいと考えています。

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

しかし、.txtで保存はできるのですが、時刻が更新されず、ずっと最初に記録した時刻のままで追記されていきます。

該当のソースコード

import threading
import RPi.GPIO as GPIO
import sys
import os
import shutil
import time
import datetime as dt
import datetime
from time import sleep


#PIN NO SET
LED1 = 16
PIR = 11

GPIO.setmode(GPIO.BOARD)
GPIO.setup(LED1, GPIO.OUT)
GPIO.setup(PIR, GPIO.IN)

GPIO.output(LED1, True)
time.sleep(2.0)
GPIO.output(LED1, False)

d = datetime.datetime.now()

#LED ON OFF Thread
def ledmain():
    global stopstr1
    stopstr1 = " "
    while True:
        sleep(1)
        if ( stopstr1 != " "):
                GPIO.cleanup()
                sys.exit()

        #LED ON OFF
        if ( GPIO.input(PIR) == GPIO.HIGH):
               led01()

#INTERRUPT Thread
def stopinput():
       global stopstr1


#led01
def led01():
    with open('gps.txt', "a", encoding='utf-8')as f:
                  print('detection!{0:%Y-%m-%d %H:%M:%S}'.format(d), file=f)
    GPIO.output(LED1, True)
    time.sleep(0.2)
    GPIO.output(LED1, False)
    time.sleep(0.2)


#SET Thread
th=threading.Thread(target=stopinput)
th.start()
th2=threading.Thread(target=ledmain)
th2.start()

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

Raspberry pi zero w の、Python3.5.3です。よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 3

checkベストアンサー

+1

d = datetime.datetime.now()led01()メソッドの最初でやればいい気が。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

print('detection!{0:%Y-%m-%d %H:%M:%S}'.format(datetime.datetime.now()), file=f)

じゃダメなんすかね?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

そりゃ現在時刻を最初だけ取得して使いまわししてるんだから、取得時の時刻しか出ないのは当たり前のはなしですね

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 87.91%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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