"""
Export simulation results to various formats.
"""
import pandas as pd
import os
from datetime import datetime


def export_results(results, output_path, method_name=None, also_per_n=True):
    """
    Export simulation results to Excel or CSV.
    
    Parameters
    ----------
    results : pd.DataFrame
        Simulation results
    output_path : str
        Output file path (.xlsx or .csv)
    method_name : str, optional
        Method name for file naming
    also_per_n : bool, default=True
        Also create separate sheets/files for each n
        
    Returns
    -------
    success : bool
        Whether export succeeded
    """
    if output_path is None:
        # Generate default path
        timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
        method_str = f"_{method_name}" if method_name else ""
        output_path = f"cobet_results{method_str}_{timestamp}.xlsx"
    
    # Ensure directory exists
    output_dir = os.path.dirname(output_path)
    if output_dir and not os.path.exists(output_dir):
        os.makedirs(output_dir, exist_ok=True)
    
    # Determine format from extension
    _, ext = os.path.splitext(output_path)
    
    if ext.lower() == '.xlsx':
        return _export_excel(results, output_path, also_per_n)
    elif ext.lower() == '.csv':
        return _export_csv(results, output_path, also_per_n)
    else:
        # Default to Excel
        return _export_excel(results, output_path, also_per_n)


def _export_excel(results, output_path, also_per_n):
    """Export to Excel with multiple sheets."""
    try:
        # Try openpyxl first
        with pd.ExcelWriter(output_path, engine='openpyxl') as writer:
            # Combined sheet
            results.to_excel(writer, sheet_name='combined', index=False)
            
            # Per-n sheets if requested
            if also_per_n and 'n' in results.columns:
                for n in sorted(results['n'].unique()):
                    df_n = results[results['n'] == n]
                    df_n.to_excel(writer, sheet_name=f'n={n}', index=False)
        
        print(f"Successfully saved results to: {output_path}")
        return True
        
    except ImportError:
        try:
            # Try xlsxwriter
            with pd.ExcelWriter(output_path, engine='xlsxwriter') as writer:
                results.to_excel(writer, sheet_name='combined', index=False)
                
                if also_per_n and 'n' in results.columns:
                    for n in sorted(results['n'].unique()):
                        df_n = results[results['n'] == n]
                        df_n.to_excel(writer, sheet_name=f'n={n}', index=False)
            
            print(f"Successfully saved results to: {output_path}")
            return True
            
        except ImportError:
            print("Warning: No Excel engine available (openpyxl or xlsxwriter).")
            print("Falling back to CSV export...")
            # Change extension to .csv
            csv_path = output_path.rsplit('.', 1)[0] + '.csv'
            return _export_csv(results, csv_path, also_per_n)


def _export_csv(results, output_path, also_per_n):
    """Export to CSV file(s)."""
    try:
        # Save combined results
        results.to_csv(output_path, index=False)
        print(f"Successfully saved results to: {output_path}")
        
        # Save per-n files if requested
        if also_per_n and 'n' in results.columns:
            base_path = output_path.rsplit('.', 1)[0]
            for n in sorted(results['n'].unique()):
                df_n = results[results['n'] == n]
                n_path = f"{base_path}_n{n}.csv"
                df_n.to_csv(n_path, index=False)
                print(f"Saved n={n} results to: {n_path}")
        
        return True
        
    except Exception as e:
        print(f"Error saving results: {e}")
        return False


def print_summary(results):
    """
    Print a summary of simulation results.
    
    Parameters
    ----------
    results : pd.DataFrame
        Simulation results
    """
    if 'method' in results.columns:
        methods = results['method'].unique()
        print(f"\n{'='*60}")
        print(f"Results Summary - Methods: {', '.join(methods)}")
        print(f"{'='*60}\n")
    
    # Group by key factors
    if all(col in results.columns for col in ['n', 'transform', 'metric']):
        for n in sorted(results['n'].unique()):
            df_n = results[results['n'] == n]
            print(f"\n--- Sample size n={n} ---")
            
            for transform in sorted(df_n['transform'].unique()):
                df_t = df_n[df_n['transform'] == transform]
                
                # Type I error
                type1 = df_t[df_t['metric'] == 'typeI']
                if not type1.empty:
                    val = type1['value'].iloc[0]
                    print(f"  {transform:10s} - Type I: {val:.4f}")
                
                # Power
                power = df_t[df_t['metric'] == 'power'].sort_values('b')
                if not power.empty:
                    for _, row in power.iterrows():
                        print(f"  {transform:10s} - Power (b={row['b']:.2f}): {row['value']:.4f}")
    
    print(f"\n{'='*60}\n")
