Запись метки времени для файла каждый час в Python - PullRequest
3 голосов
/ 05 февраля 2010

У меня есть скрипт на python, который постоянно извлекает данные из Twitter и записывает сообщения в файл. Вопрос, который у меня возникает каждый час, я хочу, чтобы моя программа записывала текущее время в файл. Ниже мой сценарий. В настоящее время он входит в функцию отметки времени и просто печатает время каждые 10 секунд.

#! /usr/bin/env python
import tweetstream
import simplejson
import urllib
import time
import datetime
import sched

class twit: 
    def __init__(self,uname,pswd,filepath):
        self.uname=uname
        self.password=pswd
        self.filepath=open(filepath,"wb")

    def main(self):
        i=0
        s = sched.scheduler(time.time, time.sleep)
        output=self.filepath

        #Grab every tweet using Streaming API
        with tweetstream.TweetStream(self.uname, self.password) as stream:
            for tweet in stream:
                if tweet.has_key("text"):
                    try:
                        #Write tweet to file and print it to STDOUT
                        message=tweet['text']+ "\n"
                        output.write(message)
                        print tweet['user']['screen_name'] + ": " + tweet['text'], "\n"

                        ################################
                        #Timestamp code
                        #Timestamps should be placed once every hour
                        s.enter(10, 1, t.timestamp, (s,))
                        s.run()
                    except KeyError:
                        pass
    def timestamp(self,sc):
        now = datetime.datetime.now()
        current_time= now.strftime("%Y-%m-%d %H:%M")
        print current_time
        self.filepath.write(current_time+"\n")


if __name__=='__main__':
    t=twit("rohanbk","cookie","tweets.txt")
    t.main()

В любом случае, мой сценарий может выполнить это, не проверяя время каждую минуту с помощью оператора IF, чтобы увидеть, сколько времени прошло? Могу ли я использовать запланированное задание, например, как я делал выше, с небольшим изменением моей текущей реализации?

1 Ответ

4 голосов
/ 05 февраля 2010

ваш код

sc.enter(10, 1, t.timestamp, (sc,)

просит, чтобы его снова запланировали через 10 секунд. Если вы хотите быть запланированы один раз в час,

sc.enter(3600, 1, t.timestamp, (sc,)

кажется лучше, поскольку час - 3600 секунд, а не 10!

Также линия

s.enter(1, 1, t.timestamp, (s,))

получает отметку времени в 1 секунду после каждого написанного твита - какой смысл в том, что ? Просто запланируйте первый вызов отметки времени один раз, вне цикла, а также измените его периодичность с 10 секунд до 3600.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...