#!/usr/bin/env python """ Script to st all models that match specific name patterns g with their dataset sizes. """ import argparse from database.models import Model, Dataset from database.utils import session_scope from sqlalchemy import or_ import pandas as pd def st_models(name_patterns, output_csv=None, show_detail=False):  """  st all models matching the provided name patterns.  Args:  name_patterns: st of bstrings to search for in model weights_location  output_csv: Optional path to save relts as CSV  show_detail: Whether to show detailed information about each model  """  with session_scope() as session:  # Build filter conditions  filter_conditions = [Model.weights_location.contains(pattern) for pattern in name_patterns]  # Query models  models = session.query(Model).filter(or_(*filter_conditions)).all()  print(f'Found {len(models)} matching models\n')  if not models:  return  # Prepare data for display and CSV  model_data = []  for model in models:  # Get dataset size  dataset_size = None  if model.dataset_id:  dataset = session.query(Dataset).filter(Dataset.id == model.dataset_id).first()  if dataset:  dataset_size = dataset.row_count  # Add to model data st  model_data.append({  'model_id': str(model.id),  'weights_location': model.weights_location,  'dataset_size': dataset_size,  'creation_time': model.creation_time  })  # Display detailed information if requested  if show_detail:  print(f'Model ID: {model.id}')  print(f'Weights Location: {model.weights_location}')  print(f'Creation Time: {model.creation_time}')  if dataset_size:  print(f'Dataset Size: {dataset_size} rows')  print('-' * 50)  # Create a DataFrame  df = pd.DataFrame(model_data)  # Sort by weights_location for easier reading  df = df.sort_values('weights_location')  # Print tabular mmary  print("Model mmary:")  print(f"{'Weights Location':<60} {'Dataset Size':<15} {'Creation Time':<25}")  print('-' * 100)  for _, row in df.iterrows():  dataset_size = str(row['dataset_size']) if row['dataset_size'] else 'N/A'  print(f"{row['weights_location']:<60} {dataset_size:<15} {row['creation_time']}")  # Save to CSV if requested  if output_csv:  df.to_csv(output_csv, index=False)  print(f'\nRelts saved to {output_csv}') def main():  parser = argparse.ArgumentParser(description='st models matching name patterns')  parser.add_argument('--patterns', nargs='+', required=True,  help='st of name patterns to search for in model weights_location')  parser.add_argument('--output', help='Optional path to save relts as CSV')  parser.add_argument('--detail', action='store_true', help='Show detailed information about each model')  args = parser.parse_args()  st_models(args.patterns, args.output, args.detail) if __name__ == '__main__':  main()