# -*- coding: utf-8 -*-
"""
Utility helpers: safe writing & Excel aggregation.
"""
import os
import pandas as pd

def ensure_dirs(*paths):
    for p in paths:
        os.makedirs(p, exist_ok=True)

def to_excel(sheets: dict, out_path: str) -> str:
    """
    sheets: mapping {sheet_name: DataFrame or CSV path}
    If value is a str path, it will be read as CSV.
    """
    with pd.ExcelWriter(out_path, engine="xlsxwriter") as writer:
        for name, obj in sheets.items():
            if isinstance(obj, str) and os.path.exists(obj):
                df = pd.read_csv(obj)
            else:
                df = obj
            df.to_excel(writer, sheet_name=name[:31], index=False)
    return out_path
