Copier une feuille de calcul entre un classeur Excel à l'aide d'Aspose.Cells

Introduction

Le transfert de données entre classeurs Excel est une tâche courante dans les applications .NET, en particulier pour générer des rapports ou gérer des modèles. Heureusement, l’utilisation d’Aspose.Cells pour .NET rend ce processus simple et efficace. Dans ce didacticiel, nous vous guiderons à travers les étapes de copie d’une feuille de calcul d’un classeur à un autre, vous offrant ainsi un contrôle puissant sur la gestion de vos données.

Prérequis

Avant de commencer, assurez-vous de disposer des outils suivants :

  1. Bibliothèque Aspose.Cells pour .NET : Télécharger la bibliothèqueici.
  2. Visual Studio ou IDE similaire : vous l’utiliserez pour écrire et exécuter votre code .NET.
  3. Licence Aspose : Pour contourner les limitations d’évaluation, vous pouvezdemander un essai gratuit ou obtenir unpermis temporaire.

Paquets d’importation

Commencez par importer les espaces de noms nécessaires dans votre projet :

using System.IO;
using Aspose.Cells;
using System;

Ces espaces de noms vous donneront accès aux classes nécessaires pour manipuler efficacement les classeurs et les feuilles de calcul Excel.

Étape 1 : définir le chemin du répertoire

Tout d’abord, définissez le répertoire dans lequel stocker vos classeurs Excel. Cela simplifiera l’accès aux fichiers par la suite.

// Définissez le chemin d’accès à votre répertoire de documents.
string dataDir = "Your Document Directory";

Remplacer"Your Document Directory" avec votre chemin actuel.

Étape 2 : Créer le premier classeur

Créons un nouveau classeur et ajoutons-y une feuille de calcul.

// Créer un nouveau classeur.
Workbook excelWorkbook0 = new Workbook();
// Accédez à la première feuille de calcul du classeur.
Worksheet ws0 = excelWorkbook0.Worksheets[0];

Étape 3 : Ajouter des données d’en-tête

Remplissez la feuille de calcul avec des lignes d’en-tête pour représenter clairement votre ensemble de données.

// Remplir les lignes d’en-tête (A1 : A4).
for (int i = 0; i < 5; i++)
{
    ws0.Cells[i, 0].PutValue($"Header Row {i}");
}

Étape 4 : Renseigner les lignes de données détaillées

Ajoutez du contenu détaillé pour fournir un contexte à votre feuille de calcul.

// Remplir les lignes de détails (A5:A999).
for (int i = 5; i < 1000; i++)
{
    ws0.Cells[i, 0].PutValue($"Detail Row {i}");
}

Étape 5 : Configurer les paramètres d’impression

Configurez la configuration de la page pour répéter les lignes d’en-tête sur les pages imprimées, ce qui est particulièrement utile pour les rapports volumineux.

// Configurez la configuration de la page pour répéter les lignes d'en-tête sur chaque page.
PageSetup pageSetup = ws0.PageSetup;
pageSetup.PrintTitleRows = "$1:$5";

Étape 6 : Créer le deuxième classeur

Ensuite, créez le deuxième classeur qui recevra la feuille de calcul copiée.

// Créer un autre classeur.
Workbook excelWorkbook1 = new Workbook();
// Accédez à la première feuille de calcul du classeur.
Worksheet ws1 = excelWorkbook1.Worksheets[0];

Étape 7 : renommer la feuille de calcul de destination

Renommez la feuille de calcul dans le deuxième classeur pour une identification facile.

// Renommer la feuille de calcul.
ws1.Name = "MySheet";

Étape 8 : Copier les données vers la feuille de calcul de destination

Utilisez leCopy méthode pour transférer la feuille de calcul entière du premier classeur au second.

//Copiez les données de la première feuille de calcul du premier classeur dans la première feuille de calcul du deuxième classeur.
ws1.Copy(ws0);

Étape 9 : Enregistrer le classeur final

Enfin, enregistrez le classeur modifié.

// Enregistrez le deuxième classeur.
excelWorkbook1.Save(dataDir + "CopyWorksheetFromWorkbookToOther_out.xls");

Conclusion

Et voilà ! Vous pouvez facilement copier une feuille de calcul d’un classeur à un autre à l’aide d’Aspose.Cells pour .NET. Cette méthode est idéale pour les grands ensembles de données, la création de modèles et la génération de rapports.

FAQ

Puis-je copier plusieurs feuilles de calcul à la fois ?

Oui, vous pouvez parcourir plusieurs feuilles de calcul et les copier individuellement dans un autre classeur.

Aspose.Cells conserve-t-il la mise en forme pendant la copie ?

Absolument! LeCopy la méthode préserve tous les formats et styles.

Comment puis-je accéder à des cellules spécifiques dans la feuille de calcul copiée ?

Vous pouvez accéder à des cellules spécifiques en utilisant leCells propriété dans la feuille de calcul.

Que faire si je souhaite uniquement copier des valeurs sans formatage ?

Vous pouvez implémenter une méthode personnalisée pour copier les valeurs cellule par cellule si vous préférez.

Puis-je tester cette fonctionnalité sans licence ?

Oui, Aspose propose unessai gratuit pour explorer ses fonctionnalités.