- metadata.create_all()
-
- # SQLAlchemy is retarded and there is no way for me to get a list of ORM
- # classes besides to inspect the module they all happen to live in for
- # things that look right.
- table_base = tables_module.TableBase
- orm_classes = {} # table object => table class
-
- for name in dir(tables_module):
- # dir() returns strings! How /convenient/.
- thingy = getattr(tables_module, name)
-
- if not isinstance(thingy, type):
- # Not a class; bail
- continue
- elif not issubclass(thingy, table_base):
- # Not a declarative table; bail
- continue
- elif thingy == table_base:
- # Declarative table base, so not a real table; bail
- continue
-
- # thingy is definitely a table class! Hallelujah.
- orm_classes[thingy.__table__] = thingy
-
- # Okay, run through the tables and actually load the data now
- for table_obj in metadata.sorted_tables:
- table_class = orm_classes[table_obj]
- table_name = table_obj.name
-
- # Print the table name but leave the cursor in a fixed column
- print table_name + '...', ' ' * (40 - len(table_name)),
-
- try:
- csvfile = open("%s/%s.csv" % (directory, table_name), 'rb')
- except IOError:
- # File doesn't exist; don't load anything!
- print 'no data!'
- continue
-
- reader = csv.reader(csvfile, lineterminator='\n')
- column_names = [unicode(column) for column in reader.next()]
-
- for csvs in reader:
- row = table_class()
-
- for column_name, value in zip(column_names, csvs):
- column = table_obj.c[column_name]
- if column.nullable and value == '':
- # Empty string in a nullable column really means NULL
- value = None
- elif isinstance(column.type, sqlalchemy.types.Boolean):
- # Boolean values are stored as string values 0/1, but both
- # of those evaluate as true; SQLA wants True/False
- if value == '0':
- value = False
- else:
- value = True
- else:
- # Otherwise, unflatten from bytes
- value = value.decode('utf-8')
-
- setattr(row, column_name, value)
-
- session.add(row)
-
- session.commit()
- print 'loaded'
-
-
-def csvexport(engine_uri, directory='.'):
- import csv
- session = connect(engine_uri)