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
Libérer: 2025-01-05 21:18:45
original
850 Les gens l'ont consulté

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);
    }
}
Copier après la connexion

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;
Copier après la connexion

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

ws.Cells[1,1].LoadFromDataTable(table, true, TableStyles.Light1);
Copier après la connexion

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);
    }
}
Copier après la connexion

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"};
}
Copier après la connexion

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 de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal