ドキュメントにはこれに関する情報が見つかりませんでしたが、SQLAlchemy で作成されたテーブルのリストを取得するにはどうすればよいでしょうか?
テーブルを作成するためにクラスメソッドを使用しました。
ベストアンサー1
すべてのテーブルは、tables
SQLAlchemy MetaData オブジェクトの属性に収集されます。これらのテーブルの名前のリストを取得するには、次のようにします。
>>> metadata.tables.keys()
['posts', 'comments', 'users']
宣言型拡張機能を使用している場合、メタデータを自分で管理していない可能性があります。幸いなことに、メタデータはベースクラスにまだ存在しています。
>>> Base = sqlalchemy.ext.declarative.declarative_base()
>>> Base.metadata
MetaData(None)
データベースにどのようなテーブルが存在するかを把握しようとしている場合、SQLAlchemy にまだ伝えていないテーブルも含めて、テーブル リフレクションを使用できます。SQLAlchemy はデータベースを検査し、不足しているすべてのテーブルでメタデータを更新します。
>>> metadata.reflect(engine)
Postgres の場合、複数のスキーマがある場合は、エンジン内のすべてのスキーマをループする必要があります。
from sqlalchemy import inspect
inspector = inspect(engine)
schemas = inspector.get_schema_names()
for schema in schemas:
print("schema: %s" % schema)
for table_name in inspector.get_table_names(schema=schema):
for column in inspector.get_columns(table_name, schema=schema):
print("Column: %s" % column)