Rendu de tableau à cellule unique SmartMarker | Aspose.Cells .NET
ArrayAsSingle conjointement avec l’attribut ExtraDelimiter, les développeurs peuvent contrôler la séparation des éléments du tableau au sein d’une seule cellule, offrant ainsi une mise en forme flexible pour les rapports et les modèles.
Introduction
Les Smart Markers dans Aspose.Cells constituent une fonctionnalité puissante, basée sur des modèles, qui vous permet de remplir dynamiquement des données de feuille de calcul à l’aide d’expressions de marqueurs telles que &=DataSource.Field. Le marqueur est placé dans un classeur concepteur, et lorsque le modèle est traité par le WorkbookDesigner, les marqueurs sont remplacés par les valeurs provenant de la source de données fournie.
Par défaut, lorsqu’un Smart Marker référence une propriété de tableau (par exemple, &=DataSource.Numbers), le moteur développe le tableau et place chaque élément dans une cellule adjacente distincte — soit horizontalement sur une ligne, soit verticalement le long d’une colonne. Bien que ce comportement soit pratique dans de nombreux scénarios, il existe des situations dans lesquelles vous préférerez rendre le tableau entier dans une seule cellule, avec les éléments concaténés et séparés par un délimiteur de votre choix.
Les attributs ArrayAsSingle et ExtraDelimiter, utilisés ensemble à l’intérieur d’une balise Smart Marker, répondent exactement à ce besoin. Ils vous permettent de conserver des mises en page de rapports compactes et prévisibles tout en travaillant nativement avec des sources de données de type tableau.
Pourquoi Cette Fonctionnalité Est Nécessaire
Comportement par Défaut de Diffusion de Tableau
Lorsqu’un Smart Marker référence une propriété de tableau, Aspose.Cells développe le tableau sur plusieurs cellules par défaut. Par exemple, un marqueur tel que &=Product.Tags appliqué à un string[] contenant quatre valeurs placera chaque valeur dans sa propre cellule, repoussant le reste du contenu du modèle et pouvant potentiellement compromettre des mises en page de rapport soigneusement conçues.
Limitations des Cas d’Usage
Il existe de nombreux scénarios pratiques où le comportement de diffusion par défaut n’est pas souhaitable :
- Rapports de type résumé qui nécessitent une disposition compacte d’une ligne par enregistrement.
- Listes de balises, d’étiquettes ou de mots-clés qui doivent être affichées sous forme de valeurs séparées par des virgules ou des barres verticales dans une seule cellule.
- Pastilles de filtre ou indicateurs d’état qui regroupent plusieurs valeurs en un seul endroit pour une meilleure lisibilité.
- Pipelines en aval (export CSV, rendu PDF, publipostage) qui attendent une valeur consolidée unique par cellule plutôt qu’une plage étendue.
- Compatibilité multiplateforme, où certains consommateurs ne peuvent pas tolérer des tableaux qui se répandent sur plusieurs cellules.
Le Manque Qu’elle Comble
Sans mécanisme intégré, les développeurs seraient contraints de prétraiter les données en C# ou VB.NET — en joignant les tableaux en chaînes délimitées avant de les lier au concepteur de classeur. Cela duplique la logique, complique les modèles de données et augmente le risque d’erreurs. Les attributs ArrayAsSingle et ExtraDelimiter éliminent cette solution de contournement en gérant la mise en forme de manière déclarative à l’intérieur du Smart Marker lui-même.
Avantages de la Fonctionnalité
L’utilisation des attributs ArrayAsSingle et ExtraDelimiter dans vos Smart Markers offre plusieurs avantages :
- Confinement dans une seule cellule : tous les éléments du tableau sont rendus dans exactement une seule cellule, maintenant des mises en page compactes et prévisibles.
- Contrôle personnalisé du délimiteur : spécifiez n’importe quelle chaîne de séparation que vous souhaitez — virgule, point-virgule, trait d’union, barre verticale, saut de ligne ou tout autre texte personnalisé.
- Mise en forme pilotée par le modèle : aucun code supplémentaire n’est requis pour prétraiter les données ; les règles de mise en forme résident dans la balise Smart Marker.
- Rapports plus propres : les données de tableau ne poussent plus le contenu voisin du modèle dans des lignes ou des colonnes différentes.
- Types de données polyvalents : fonctionne avec les chaînes, les nombres, les dates et tout autre type de données pouvant être joint avec un délimiteur.
- Rétrocompatibilité : lorsque les attributs sont omis, le comportement de diffusion d’origine est préservé, de sorte que les modèles existants continuent de fonctionner sans modification.
Comment Utiliser Cette Fonctionnalité
Syntaxe du Smart Marker
Les attributs ArrayAsSingle et ExtraDelimiter sont passés sous forme de paires clé-valeur à l’intérieur des parenthèses d’un Smart Marker standard. La syntaxe générale est :
&=DataSource.ArrayProperty(arrayasSingle=true, extraDelimiter=", ")
Le marqueur est composé des parties suivantes :
&=DataSource.ArrayProperty— le Smart Marker standard référençant la propriété de tableau sur la source de données liée.arrayasSingle=true— indique au moteur de rendre le tableau entier dans une seule cellule. Seule la valeurtruedéclenche le comportement de cellule unique.extraDelimiter=", "— définit le séparateur placé entre les éléments du tableau. La valeur est une chaîne littérale ; elle peut être vide, un seul caractère ou une chaîne à plusieurs caractères.
extraDelimiter accepte n’importe quelle chaîne littérale, y compris les délimiteurs à plusieurs caractères, le texte personnalisé ou les séquences d’échappement telles que \n pour une sortie séparée par des sauts de ligne. Si le tableau est vide, la cellule résultante est laissée vide.
Flux de Travail Étape par Étape
Le flux de travail suivant décrit comment rendre un tableau dans une seule cellule à l’aide des Smart Markers.
- Préparez la source de données : créez une classe (ou une structure de données) qui expose une propriété renvoyant un tableau. La propriété peut renvoyer
string[],int[]ou tout autre type de tableau pris en charge. - Créez un classeur concepteur : créez un nouveau
Workbook, ajoutez une ligne d’en-tête et placez une cellule Smart Marker qui référence la propriété de tableau avec les attributsarrayasSingleetextraDelimiter. - Instanciez le WorkbookDesigner : créez un objet
WorkbookDesigner, attachez-lui le classeur concepteur et liez votre source de données à l’aide de la méthodeSetDataSource. - Traitez les marqueurs : appelez la méthode
WorkbookDesigner.Process()pour développer les Smart Markers et remplir le classeur avec les données réelles. - Enregistrez le résultat : enregistrez le classeur résultant sur le disque au format XLSX ou dans tout autre format de fichier pris en charge.
Exemple de Code 1 — Rendu de Tableau de Chaînes Basique
using System;
using Aspose.Cells;
class Program
{
public class Product
{
public string[] Tags { get; set; }
}
public static void Main()
{
Product product = new Product
{
Tags = new string[] { "C#", "Aspose", "SmartMarker", "Excel" }
};
Workbook workbook = new Workbook();
Worksheet worksheet = workbook.Worksheets[0];
worksheet.Cells["A1"].PutValue("Tags");
worksheet.Cells["A2"].PutValue("&=Product.Tags(arrayasSingle=true, extraDelimiter=\", \")");
WorkbookDesigner designer = new WorkbookDesigner();
designer.Workbook = workbook;
designer.SetDataSource("Product", product);
designer.Process();
workbook.Save("output_arraySingle.xlsx");
}
}
Exemple de Code 2 — Tableau Numérique avec Délimiteur Personnalisé
public class Student
{
public int[] Scores { get; set; }
}
public class Program
{
public static void Main()
{
var student = new Student
{
Scores = new int[] { 95, 88, 76, 100, 67 }
};
var workbook = new Workbook();
var worksheet = workbook.Worksheets[0];
worksheet.Cells["A1"].PutValue("Scores");
worksheet.Cells["A2"].PutValue(string.Join(" - ", student.Scores));
workbook.Save("output_numericArray.xlsx");
}
}
Exemple de Code 3 — Comparaison du Comportement par Défaut vs. ArrayAsSingle
using System;
using Aspose.Cells;
public class Program
{
public static void Main()
{
var order = new Order
{
Items = new string[] { "Apple", "Banana", "Cherry", "Date" }
};
var workbook = new Workbook();
var sheet = workbook.Worksheets[0];
var cells = sheet.Cells;
// Section 1 : Smart Marker par défaut - valeurs réparties horizontalement dans les cellules
cells["A1"].PutValue("Default Spreading Behavior:");
cells["A2"].PutValue("&=Order.Items");
// Section 2 : Nouveau rendu en cellule unique utilisant arrayasSingle et extraDelimiter
cells["A4"].PutValue("Single Cell Rendering (arrayasSingle=true):");
cells["A5"].PutValue("&=Order.Items(arrayasSingle=true, extraDelimiter=\"; \")");
// Lier la source de données et traiter les Smart Markers
var designer = new WorkbookDesigner(workbook);
designer.SetDataSource("Order", order);
designer.Process();
// Enregistrer le classeur résultant
workbook.Save("output_comparison.xlsx");
}
}
public class Order
{
public string[] Items { get; set; }
}
Notes et Bonnes Pratiques
Gardez les points suivants à l’esprit lorsque vous travaillez avec les attributs ArrayAsSingle et ExtraDelimiter :
- La valeur de
extraDelimiterest traitée comme une chaîne littérale ; échappez tous les caractères spéciaux que votre processeur de modèle pourrait interpréter. - L’attribut
arrayasSingleaccepte une valeur booléenne (true/false). Seultruedéclenche le comportement de cellule unique ; toute autre valeur revient au comportement de diffusion par défaut. - Si le tableau est vide ou nul, la cellule est laissée vide (ou contient une chaîne vide selon le type de données).
- La fonctionnalité fonctionne avec des sources de données d’objets ainsi qu’avec des sources
DataSetetDataTableoù une colonne peut être divisée en tableaux. - Pour une sortie séparée par des sauts de ligne, vous pouvez utiliser
\nouEnvironment.NewLinecomme valeur de délimiteur. - Placez le Smart Marker dans une cellule dont la largeur est suffisante pour afficher la chaîne concaténée résultante ; sinon, le contenu peut visuellement déborder dans les cellules adjacentes selon le format.