Importer des données à partir d un DataTable dans une grille
Exemple
Pour importer le contenu d’un tableau de données à l’aide du contrôle Aspose.Cells.GridDesktop :
- Ajouter le contrôle Aspose.Cells.GridDesktop à un formulaire.
- Créer un objet DataTable contenant les données à importer.
- Obtenez la référence d’une feuille de calcul souhaitée.
- Importer le contenu du tableau de données dans la feuille de travail.
- Définir les en-têtes de colonne de la feuille de travail selon les noms de colonne du tableau de données.
- Définir la largeur des colonnes, si nécessaire.
- Afficher la feuille de travail.
Dans l’exemple ci-dessous, nous avons créé un objet DataTable et l’avons rempli avec des données extraites d’une table de base de données nommée Produits. Enfin, nous avons importé les données de cet objet DataTable dans une feuille de travail souhaitée à l’aide de Aspose.Cells.GridDesktop.
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET | |
// The path to the documents directory. | |
string dataDir = Utils.GetDataDir(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); | |
OleDbDataAdapter adapter; | |
DataTable dt = new DataTable(); | |
// Creating connection string to connect with database | |
string conStr = @"Provider=microsoft.jet.oledb.4.0;Data Source=" + dataDir + "dbDatabase.mdb"; | |
// Creating Select query to fetch data from database | |
string query = "SELECT * FROM Products ORDER BY ProductID"; | |
adapter = new OleDbDataAdapter(query, conStr); | |
// Filling DataTable using an already created OleDbDataAdapter object | |
adapter.Fill(dt); | |
// Accessing the reference of a worksheet | |
Worksheet sheet = gridDesktop1.Worksheets[0]; | |
// Importing data from DataTable to the worksheet. 0,0 specifies to start importing data from the cell with first row (0 index) and first column (0 index) | |
sheet.ImportDataTable(dt, false, 0, 0); | |
// Iterating through the number of columns contained in the DataTable | |
for (int i = 0; i < dt.Columns.Count; i++) | |
{ | |
// Setting the column headers of the worksheet according to column names of the DataTable | |
sheet.Columns[i].Header = dt.Columns[i].Caption; | |
} | |
// Setting the widths of the columns of the worksheet | |
sheet.Columns[0].Width = 240; | |
sheet.Columns[1].Width = 160; | |
sheet.Columns[2].Width = 160; | |
sheet.Columns[3].Width = 100; | |
// Displaying the contents of the worksheet by making it active | |
gridDesktop1.ActiveSheetIndex = 0; |