Aller au contenu principal
Version: 20 R7

VP CREATE TABLE

Historique
ReleaseModifications
19 R8Support of theme options: bandColumns, bandRows, highlightFirstColumn, highlightLastColumn, theme
19 R7Support of allowAutoExpand option
19 R6Ajout

VP CREATE TABLE ( rangeObj : Object ; tableName : Text {; source : Text} {; options : cs.ViewPro.TableOptions} )

ParamètresTypeDescription
rangeObjObject->Objet plage
tableNameText->Nom de la table
sourceText->Nom de la propriété du Data context à afficher dans la table
optionscs.ViewPro.TableOptions->Options supplémentaires

Description

La commande VP CREATE TABLE crée une table dans la plage spécifiée. Vous pouvez créer une table dans une plage de cellules pour faciliter la gestion et l'analyse d'un groupe de données connexes. Une table contient généralement des données connexes en lignes et en colonnes, et tire parti d'un contexte de données.

Dans rangeObj, passez la plage de cellules où la table sera créée.

Dans tableName, passez un nom pour la table. Le nom doit :

  • être unique dans la feuille
  • inclure au moins 5 caractères
  • ne pas inclure d'espaces ou commencer par un nombre

Dans source, vous pouvez passer un nom de propriété d'un [data context] (vp-set-data-context.md) pour afficher ses données dans le tableau. This binds the table to the data context. When the data context is updated, the data displayed in the table is updated accordingly. La propriété source doit contenir une collection d'objets et chaque élément représente une ligne.

  • Si vous ne spécifiez pas de source, la commande crée une table vide avec la taille définie dans rangeObj.
  • Si la source spécifiée ne peut pas être entièrement affichée dans le document, aucune table n'est créée.

Dans le paramètre options, passez un objet de la classecs.ViewPro.TableOptions qui contient les propriétés de la table à définir.

Dans l'objet options, la collection tableColumns détermine la structure des colonnes de la table. La longueur de la collection tableColumns doit être égale au nombre de colonnes de la plage :

  • Lorsque le nombre de colonnes dans rangeObj dépasse le nombre de colonnes dans tableColumns, la table est remplie avec des colonnes vides supplémentaires.
  • Lorsque le nombre de colonnes dans rangeObj est inférieur au nombre de tableColumns, le tableau affiche un nombre de colonnes correspondant au nombre de colonnes de la plage.

Si vous passez une option source mais pas une option tableColumn, la commande génère automatiquement des colonnes. Dans ce cas, rangeObj doit être une plage de cellules. Otherwise, the first cell of the range is used. When generating columns automatically, the following rules apply:

  • If the data passed to the command is a collection of objects, the property names are used as column titles. Par exemple :
([{ LastName: \"Freehafer\", FirstName: \"Nancy\"},{ LastName: \"John\", FirstName: \"Doe\"})

Ici, les titres des colonnes seraient LastName et FirstName.

  • If the data passed to the command is a collection of scalar values, it must contain a collection of subcollections:

    • La collection de premier niveau contient des sous-collections de valeurs. Chaque sous-collection définit une ligne. Passez une collection vide pour sauter une ligne. The number of values in the first subcollection determines how many columns are created.
    • The subcollections' indices are used as column titles.
    • Chaque sous-collection définit les valeurs des cellules de la ligne. Les valeurs peuvent être Integer, Real, Boolean, Text, Date, Null, Time ou Picture. Une valeur Time doit être un objet contenant un attribut time, comme décrit dans VP SET VALUE.

This only works when generating columns automatically. Vous ne pouvez pas utiliser une collection de données scalaires avec l'option tableColumns.

Exemple

Pour créer une table en utilisant un contexte de données :

// Set a data context
var $data : Object

$data:=New object()
$data.people:=New collection()
$data.people.push(New object("firstName"; "John"; "lastName"; "Smith"; "email"; "johnsmith@gmail.com"))
$data.people.push(New object("firstName"; "Mary"; "lastName"; "Poppins"; "email"; "marypoppins@gmail.com"))


VP SET DATA CONTEXT("ViewProArea"; $data)

// Define the columns for the table
var $options : cs.ViewPro.TableOptions

$options:=cs.ViewPro.TableOptions.new()
$options.tableColumns:=New collection()
$options.tableColumns.push(New object("name"; "First name"; "dataField"; "firstName"))
$options.tableColumns.push(New object("name"; "Last name"; "dataField"; "lastName"))
$options.tableColumns.push(New object("name"; "Email"; "dataField"; "email"))

// Create a table from the "people" collection
VP CREATE TABLE(VP Cells("ViewProArea"; 1; 1; $options.tableColumns.length; 1); "ContextTable"; "people"; $options)

Voici le résultat :

Voir également

VP Find table
VP Get table column attributes
VP Get table column index
VP INSERT TABLE COLUMNS
VP INSERT TABLE ROWS
VP REMOVE TABLE
VP RESIZE TABLE
VP SET DATA CONTEXT
VP SET TABLE COLUMN ATTRIBUTES
VP SET TABLE THEME