わかりましたので、すべての車のオブジェクトを印刷しようとしています... 2 つの質問があります。
- 私が実装している方法は
__iter__
受け入れられますか? - 私は今欲しい結果を得ていますが、結果はかなり醜いです...印刷をフォーマットして見栄えを良くする方法はありますか?
これが私のコードです:
import sqlite3
class Database:
def __init__(self, **kwargs):
self.filename = kwargs.get('filename')
def __iter__(self):
car_object = {}
cursor = self._db.execute('select * from CARS'.format(self._table))
for row in cursor:
objectname = str(row['IDENT'])
car_object[objectname] = Cars(make = row['MAKE'],
model = row['MODEL'], disp = row['DISPLACEMENT'],
power = row['POWER'], luxury = row['LUXURY'])
yield dict(row)
@property
def filename(self):
return self._filename
@filename.setter
def filename(self, fn):
self._filename = fn
self._db = sqlite3.connect(fn)
self._db.row_factory = sqlite3.Row
class Cars:
def __init__(self, **kwargs):
self.variables = kwargs
def set_Variable(self, k, v):
self.variables[k] = v
def get_Variable(self, k):
return self.variables.get(k, None)
def main():
db = Database(filename = 'insurance.sqlite')
print ('IDENT MAKE MODEL
DISPLACEMENT POWER LUXURY')
for item in db:
print(item['IDENT'], ' ', item['MAKE'], ' ',
item['MODEL'],' ', item['DISPLACEMENT'],
' ', item['POWER'],' ', item['LUXURY'])
if __name__ == "__main__": main()