2016-11-20 2 views
0

J'essaie d'ajouter une liste des abonnés soundcloud de quelqu'un à une base de données toutes les heures. J'ai le code qui fonctionne pour tirer leur liste de suiveurs et les ajouter à un db, mais je rencontre des erreurs quand je l'utilise avec apscheduler.Apscheduler s'exécute une fois puis lance TypeError

Voici un exemple de l'erreur:

Traceback (most recent call last): 
    File "desktop/SoundcloudProject/artistdailyfollowers.py", line 59, in <module> 
    scheduler.add_job(inserttodaysdata(), 'interval', hours=1) 
    File "//anaconda/lib/python3.5/site-packages/apscheduler/schedulers/base.py", line 425, in add_job 
    job = Job(self, **job_kwargs) 
    File "//anaconda/lib/python3.5/site-packages/apscheduler/job.py", line 44, in __init__ 
    self._modify(id=id or uuid4().hex, **kwargs) 
    File "//anaconda/lib/python3.5/site-packages/apscheduler/job.py", line 165, in _modify 
    raise TypeError('func must be a callable or a textual reference to one') 
TypeError: func must be a callable or a textual reference to one 

Voici le code:

import soundcloud 
import sqlite3 
import datetime 
import time 
from apscheduler.schedulers.blocking import BlockingScheduler 

client = soundcloud.Client(client_id='f3b669e6e4509690939aed943c56dc99') 
conn = sqlite3.connect('desktop/SoundcloudProject/RageLogic.db') 
c = conn.cursor() 
writenow = datetime.datetime.now() 
print("If this is printing that means it's running") 
print("The time is now: \n" +str(writenow)) 
page ='https://soundcloud.com/ragelogic' 
page_size = 200 

def create_table(): 
    c.execute('CREATE TABLE IF NOT EXISTS RageLogicFollowersByDay(day TEXT, list_of_followers TEXT)') 

#add todays date and a list of followers to the db 
def inserttodaysdata(): 
    global page 
    full = False 
    user = client.get('/resolve', url=page) 
    ufollowing = [] 
    ufirstfollowing = client.get('/users/'+str(user.id)+'/followers', order='id',limit=page_size, linked_partitioning=1) 
    for user in ufirstfollowing.collection: 
     ufollowing.append(user.id) 
    if hasattr(ufirstfollowing, "next_href"): 
     #print("MANYFOLLOWING") 
     newlink = ufirstfollowing.next_href 
     try: 
      while full == False: 
       newlist = client.get(newlink) 
       for user in newlist.collection: 
        ufollowing.append(user.id) 
       print(len(ufollowing)) 
       if newlist.next_href == None: 
        print("full") 
        full = True 
       else: 
        newlink = newlist.next_href 
     except AttributeError: 
      None 

    #print(len(ufollowing)) 
    wtl = [] 
    wtl = repr(ufollowing) 
    writenow = datetime.datetime.now() 
    c.execute("INSERT INTO RageLogicFollowersByDay (day, list_of_followers) VALUES (?, ?)",(str(writenow), wtl)) 
    conn.commit() 

#create_table() 
scheduler = BlockingScheduler() 
scheduler.add_job(inserttodaysdata(), 'interval', hours=1) 
scheduler.start() 

Je suis vraiment nouveau à tout cela et tout quelqu'un d'aide pourrait donner serait génial, merci!

Répondre

0

Voir cette ligne:

scheduler.add_job(inserttodaysdata(), 'interval', hours=1) 

Vous appelez inserttodaysdata() et passer sa valeur de retour-add_job(). Ne fais pas ça. Passez la fonction elle-même, pas son résultat d'appel.

+0

Oh wow c'était bien plus facile que je ne le pensais, merci! –