Aller au contenu principal
Version: Next

VP IMPORT DOCUMENT

Historique
ReleaseModifications
20 R2Support of .sjs documents

VP IMPORT DOCUMENT ( vpAreaName : Text ; filePath : Text { ; paramObj : Object} )

ParamètresTypeDescription
vpAreaNameText->Nom d'objet formulaire zone 4D View Pro
filePathText->Chemin d'accès du document
paramObjObject->Options d'import

Description

La commande VP IMPORT DOCUMENT importe et affiche le document désigné par filePath dans la zone 4D View Pro vpAreaName. Le document importé remplace toutes les données déjà présentes dans la zone.

Dans vpAreaName, passez le nom de la zone 4D View Pro. Si vous passez un nom inexistant, une erreur est retournée.

Dans filePath, passez le chemin et le nom du document à importer. Les formats suivants sont pris en charge :

  • Les documents 4D View Pro (extension ".4vp")
  • Microsoft Excel (extension ".xlsx")
  • documents texte (extension ".txt", ".csv", le document doit être en utf-8)
  • Documents SpreadJS (extension ".sjs")

Si l'extension du document n'est pas une extension reconnue, telle que .4vp ou .xlsx, le document est considéré comme un document texte. Vous devez passer un chemin d'accès complet, sauf si le document est situé au même niveau que le dossier Project, auquel cas vous pouvez simplement passer son nom.

Une erreur est retournée si le paramètre filePath est invalide, ou si le fichier est manquant ou mal-formé.

Le paramètre optionnel paramObj vous permet de définir les propriétés du document importé:

ParamètresTypeDescription
formula4D.FunctionUne méthode callback à lancer lorsque l'import est terminé. Vous devez utiliser une formule retournée par la commande Formula. See Passing a callback method (formula).
passwordtextMicrosoft Excel uniquement (optionnel) - Mot de passe utilisé pour protéger un document Microsoft Excel.
csvOptionsobjectoptions d'import csv
rangeobjectPlage de cellules contenant la première cellule dans laquelle les données seront saisies. Si la plage spécifiée n'est pas une plage de cellules, seule la première cellule de la plage est utilisée.
rowDelimitertextDélimiteur de ligne. S'il n'est pas défini, le délimiteur est automatiquement déterminé par 4D.
columnDelimitertextDélimiteur de colonne. Par défaut : ","
sjsOptionsobjectoptions d'import sjs
calcOnDemandbooleanIndique si les formules doivent être calculées uniquement lorsqu'elles sont demandées, la valeur par défaut est faux.
dynamicReferencesbooleanIndique si les fonctions doivent être calculées avec des références dynamiques, la valeur par défaut est vrai.
fullRecalcbooleanIndique si le calcul doit être effectué après le chargement des données json, la valeur par défaut est faux.
includeFormulasbooleanWhether to include the formulas when loading, default is true.
includeStylesbooleanWhether to include the styles when loading, default is true.
includeUnusedStylesbooleanWhether to include the unused name styles when converting excel xml to the json, default is true.
openModeinteger
  • 0 (normal): normal open mode, without lazy and incremental. When opening file, UI and UI event could be refreshed and responsive at specific time points.
  • 1 (lazy): lazy open mode. When opening file, only the active sheet will be loaded directly. Other sheets will be loaded only when they are be used.
  • 2 (incremental): incremental open mode. When opening file, UI and UI event could be refreshed and responsive directly.
  • excelOptionsobjectExcel only (optional) - Options for Excel export
    includeStylesbooleanWhether to include the style when importing, default true.
    includeFormulasbooleanWhether to include the formula when importing, default true.
    frozenColumnsAsRowHeadersbooleanWhether to treat the frozen columns as row headers when importing, default false.
    frozenRowsAsColumnHeadersbooleanWhether to treat the frozen rows as column headers when importing, default false.
    fullRecalcbooleanIndique si le calcul doit être effectué après le chargement des données json, la valeur par défaut est faux.
    dynamicReferencesbooleanWhether to calculate functions with dynamic reference, default true.
    calcOnDemandbooleanWhether to calculate formulas only when they are demanded, default false.
    includeUnusedStylesbooleanWhether to include the unused name style when converting excel xml to the json, default true.
    passwordtextThe password to open the workbook.
    openModetextThe open mode of normal, lazy and incremental. By default is normal.
    Notes
    • Importing files in .xslx, .csv, and .sjs formats is asynchronous. With these formats, you must use the formula attribute if you want to start an action at the end of the document processing.
    • When importing a Microsoft Excel-formatted file into a 4D View Pro document, some settings may be lost. You can verify your settings with this list from SpreadJS.
    • Pour plus d'informations sur le format CSV et les valeurs séparées par des délimiteurs en général, voir cet article sur Wikipedia
    • Using excelOptions object is recommended when importing ".xlsx" format. Make sure to not mix this object with legacy first level property password to avoid potiental issues.

    Exemple 1

    Vous souhaitez importer un document 4D View Pro stocké sur le disque, à l'ouverture du formulaire :

    var $docPath : text
    If(Form event code=On VP Ready) //4D View Pro area loaded and ready
    $docPath:="C:\\Bases\\ViewProDocs\\MyExport.4VP"
    VP IMPORT DOCUMENT("VPArea";$docPath)
    End if

    Exemple 2

    Vous souhaitez importer un document Microsoft Excel protégé par un mot de passe dans 4D View Pro :

    	//Import code
    var $o:={}
    $o.formula:=Formula(myImport)
    $excelOptions:={includeStyles:false;includeFormulas:true;password:"excel123"}
    $o.excelOptions:=$excelOptions

    VP IMPORT DOCUMENT("ViewProArea";"c:\\tmp\\excelfile.xlsx";$o)
    	//myImport callback method
    #DECLARE($area : Text; $filePath : Text; $param : Object; $status : Object)

    If ($status.success)
    ALERT("Import successfully completed")
    Else
    ALERT("Error: "+$status.errorMessage)
    End if

    Exemple 3

    Vous souhaitez importer un fichier .txt qui utilise une virgule (",") comme délimiteur:

    example-import-csv

    var $params:={}
    $params.range:=VP Cells("ViewProArea";0;0;2;5)
    VP IMPORT DOCUMENT("ViewProArea";"c:\\import\\my-file.txt";New object("csvOptions";$params))

    Voici le résultat : example-import-csv

    Voir également

    VP EXPORT DOCUMENT
    VP NEW DOCUMENT
    4D View Pro: Excel import/export update (blog post)