Maison >développement back-end >C++ >Comment exporter des données DataTable vers un fichier Excel (.xlsx) avec le type MIME et le formatage appropriés ?

Comment exporter des données DataTable vers un fichier Excel (.xlsx) avec le type MIME et le formatage appropriés ?

DDD
DDDoriginal
2025-01-05 21:18:45808parcourir

How to Export DataTable Data to an Excel (.xlsx) File with Proper MIME Type and Formatting?

Comment exporter des données de tableau vers Excel en utilisant les méthodes appropriées et définir le type MIME correct pour un fichier Excel (xlsx) ?

Le Le guide fourni ne montre pas comment créer un fichier Excel ; à la place, il utilise une solution de contournement qui génère un fichier HTML contenant un tableau. Excel peut rencontrer des erreurs de formatage lors de la tentative d'importation de fichiers CSV ou HTML contenant des tableaux qui ne respectent pas ses paramètres par défaut.

La création d'un véritable fichier Excel à l'aide d'EPPlus est nettement plus simple. LoadFromDataTable et LoadFromCollection d'EPPlus peuvent être utilisés pour remplir une plage Excel avec les données d'un DataTable ou d'une collection générique. Les en-têtes sont générés à l'aide respectivement des noms de colonne ou de propriété.

public ActionResult ExportData()
{
    // Load data into a DataTable
    
    using (ExcelPackage package = new ExcelPackage())
    {
        var ws = package.Workbook.Worksheets.Add("My Sheet");
        // true generates headers
        ws.Cells["A1"].LoadFromDataTable(dataTable, true);

        var stream = new MemoryStream();
        package.SaveAs(stream);

        string fileName = "myfilename.xlsx";
        string contentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";

        stream.Position = 0;
        return File(stream, contentType, fileName);
    }
}

LoadFromDataTable et LoadFromCollection renvoient une plage de cellules Excel qui peut être utilisée pour appliquer le formatage au tableau :

var range = ws.Cells["A1"].LoadFromDataTable(table);
range.Style.Numberformat.Format = "#,##0.00";
range.Style.HorizontalAlignment = ExcelHorizontalAlignment.Right;

En outre , vous pouvez appliquer un style de tableau à la plage :

ws.Cells[1,1].LoadFromDataTable(table, true, TableStyles.Light1);

Format, formules, tableaux croisés dynamiques et tableau la gestion peut être trouvée dans le wiki GitHub de la bibliothèque.

L'enregistrement dans un MemoryStream peut ne pas être idéal pour les feuilles plus grandes en raison de l'écriture de données en double (dans la mémoire et le flux de sortie). Cependant, il est déconseillé de renvoyer FileResult directement à partir d'une action MVC. La solution consiste à créer un FileResult adapté aux packages EPPlus :

public class EpplusResult: FileResult
{
    public EpplusResult(ExcelPackage package)
        : base("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
    {
        Package = package;
    }

    public ExcelPackage Package { get; private set; }

    protected override void WriteFile(HttpResponseBase response)
    {
        Package.SaveAs(response.OutputStream);
    }
}

Cela permet les éléments suivants dans votre action :

public FileResult ExportData()
{
    ExcelPackage package = new ExcelPackage();
    var ws = package.Workbook.Worksheets.Add("My Sheet");       
    ...
    ws.Cells[1,1].LoadFromDataTable(table, true, TableStyles.Light1);

    return new EpplusResult(package){FileDownloadName = "SomeFile.xlsx"};
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn