class GenericDBOP:
def __init__(self, db, name):
self.db = db # соединение с базой данных
self.name = name # имя таблицы
self.dbc = self.db.cursor() # объект cursor
self.debug=1
def __getitem__(self, item):
self.dbc.execute("select * from %s limit %s, 1" %
(self.name, item))
return self.dbc.fetchone()
def _query(self, q):
if self.debug: print "Query: %s" % (q)
self.dbc.execute(q)
def __iter__(self):
"creates a data set, and returns an iterator (self)"
q = "select * from %s" % (self.name)
self._query(q)
return self # возвращаем объект Iterator
# методом next()
def next(self):
"returns the next item in the data set,
or tells Python to stop"
r = self.dbc.fetchone()
if not r:# тут ошибка обрабатывается
raise StopIteration
return r