Example #1
0
class SqliteSpiderQueue(object):

    implements(ISpiderQueue)

    def __init__(self, database=None, table="spider_queue"):
        self.q = JsonSqlitePriorityQueue(database, table)

    @classmethod
    def from_settings(cls, settings):
        return cls(sqlite_db(settings["SQLITE_DB"]))

    def add(self, name, **spider_args):
        d = spider_args.copy()
        d["name"] = name
        priority = float(d.pop("priority", 0))
        self.q.put(d, priority)

    def pop(self):
        return self.q.pop()

    def count(self):
        return len(self.q)

    def list(self):
        return [x[0] for x in self.q]

    def clear(self):
        self.q.clear()
Example #2
0
class SqliteSpiderQueue(object):

    implements(ISpiderQueue)

    def __init__(self, database=None, table='spider_queue'):
        self.q = JsonSqlitePriorityQueue(database, table)

    @classmethod
    def from_settings(cls, settings):
        return cls(sqlite_db(settings['SQLITE_DB']))

    def add(self, name, **spider_args):
        d = spider_args.copy()
        d['name'] = name
        priority = float(d.pop('priority', 0))
        self.q.put(d, priority)

    def pop(self):
        return self.q.pop()

    def count(self):
        return len(self.q)

    def list(self):
        return [x[0] for x in self.q]

    def clear(self):
        self.q.clear()
Example #3
0
 def __init__(self, database=None, table="spider_queue"):
     self.q = JsonSqlitePriorityQueue(database, table)
Example #4
0
 def __init__(self, database=None, table='spider_queue'):
     self.q = JsonSqlitePriorityQueue(database, table)