La biblioteca ScriptForge
      
  
    
    Abra  y seleccione el contenedor .
 
   
 
    Las bibliotecas de ScriptForge constituyen una amplia colección de recursos de programación para LibreOffice que pueden invocarse desde macros escritas en BASIC o secuencias de órdenes escritas en Python.
    
• Basic macros require to load ScriptForge library using the following statement:
   GlobalScope.BasicLibraries.loadLibrary("ScriptForge")
• Python scripts require an import from scriptforge module:
      from scriptforge import CreateScriptService
    
 
  
  Invocar los servicios de ScriptForge
  Los módulos y las clases que aquí se describen se pueden invocar desde secuencias de órdenes de usuario como «servicios». Para tal efecto, se ha diseñado un constructor genérico de dichos servicios para cada lenguaje:
  
    GlobalScope.BasicLibraries.LoadLibrary("ScriptForge")
    Set oSvc = CreateScriptService("servicename"[, arg0, arg1, ...])
    ' ...
    oSvc.Dispose()
  
    from scriptforge import CreateScriptService
    svc = CreateScriptService('servicename'[, arg0, arg1, ...])
    # ...
    svc.Dispose()
  
El método Dispose está disponible en todos los servicios y debería ser llamado para liberar recursos después del su uso.
  Servicios que ofrece la biblioteca ScriptForge
  
    
      
  
  
  Facilita una colección de métodos para manipular y transformar formaciones de una dimensión (vectores) y de dos (matrices). La colección incluye operaciones de conjunto, ordenación, importación y exportación a partir de archivos de texto.
  Las matrices con más de dos dimensiones no pueden utilizarse con los métodos de este servicio, siendo la única excepción el método CountDims, que acepta matrices con cualquier número de dimensiones.
 
    
    
      
  
  
  El servicio Base proporciona diversos métodos y propiedades que facilitan la gestión y la manipulación de los documentos de LibreOffice Base.
  Este servicio está estrechamente relacionado con el servicio Document, que brinda métodos genéricos para manipular documentos de LibreOffice, incluidos los de Base. De ahí que el servicio Base amplíe Document y ofrezca métodos adicionales específicos para los documentos de Base, permitiendo a los usuarios:
  
    - 
        Obtener acceso a la base de datos contenida en un documento de Base. 
- 
        Abrir los documentos de formulario almacenados en un documento de Base. 
- 
        Comprobar si un formulario de un documento de Base se encuentra cargado. 
 
    
    
      
    
  El servicio ScriptForge.Basic ofrece una colección de métodos de LibreOffice BASIC que ejecutar en un contexto Python. Los métodos del servicio Basic reproducen con exactitud la sintaxis y el comportamiento de las funciones incorporadas de BASIC.
 
    
    
      
    
    The SFDocuments shared library provides a number of methods and properties to facilitate the management and handling of LibreOffice documents.
    The SFDocuments.Calc service is a subclass of the SFDocuments.Document service. All methods and properties defined for the Document service can also be accessed using a Calc service instance.
    The Calc service is focused on:
    
        - 
            Handling sheets within a Calc document (copy, insert, move, etc) 
- 
            Exchanging data between Basic data structures and Calc ranges 
- 
            Copying and importing massive amounts of data 
 
    
    
      
    
    The Chart service provides a set of properties and methods to handle charts in Calc documents. With this service it is possible to:
    
      - 
        Acceder a los objetos de gráfico en los documentos de Calc y manipular sus propiedades. 
- 
        Create and insert new charts into a Calc document. 
- 
        Exportar los gráficos como archivos de imagen. 
 
    
    
      
    
    The Database service provides access to databases either embedded or described in Base documents. This service provides methods to:
    
      - 
        Get access to data in database tables. 
- 
        Run SELECT queries and perform aggregate functions. 
- 
        Run SQL action statements such as INSERT, UPDATE, DELETE, etc. 
 
    
    
      
  
  The Dialog service contributes to the management of dialogs created with the Basic Dialog Editor. Each instance of the current class represents a single dialog box displayed to the user.
 
    
    
      
   
  
  The DialogControl service manages the controls belonging to a dialog defined with the Basic Dialog Editor. Each instance of the current service represents a single control within a dialog box.
  
  The focus is set on getting and setting the values displayed by the controls of the dialog box. Formatting is accessible via the XControlModel and XControlView properties.
  Note that the unique DialogControl.Value property content varies according to the control type.
  A special attention is given to controls of type tree control. It is easy to populate a tree, either branch by branch, or with a set of branches at once. Populating a tree control can be performed statically or dynamically.
 
    
    
      
  
  
  A dictionary is a collection of key-item pairs
  
 
    
    
      
    
  The SFDocuments library provides methods and properties to facilitate the management and manipulation of LibreOffice documents.
  Methods that are applicable for all types of documents (Text Documents, Sheets, Presentations, etc) are provided by the SFDocuments.Document service. Some examples are:
  
  - 
    Abrir, cerrar y guardar documentos 
- 
    Acceder a propiedades estándares o personalizadas de los documentos 
 
    
    
      
  
  
  The Exception service is a collection of methods to assist in code debugging in Basic and Python scripts and in error handling in Basic scripts.
  In Basic scripts, when a run-time error occurs, the methods and properties of the Exception service help identify the error context and allow to handle it.
 
    
    
      
  
  The FileSystem service includes routines to handle files and folders. Next are some examples of the features provided by this service:
  
    - 
      Verify whether a file or folder exists. 
- 
      Create and delete folders and files. 
- 
      Launch dialog boxes to open/save files. 
- 
      Access the list of files in a folder, etc. 
 
    
    
      
  
  The Form service provides methods and properties to manage forms in LibreOffice documents. This service supports forms in Base, Calc and Writer documents and allows to:
  
    - 
        Open and activate forms. 
- 
        Navigate through records shown by the form. 
- 
        Get access to the controls inside the form. 
- 
        Get access to subforms of a parent form. 
 
    
    
      
  
  The FormControl service provides access to the controls that belong to a form, a subform or a table control of a FormDocument. Each instance of the FormControl service refers to a single control in the form. This service allows users to:
  
    - 
        Get and set the properties of the control represented by the FormControl instance. 
- 
        Access the current value displayed by the control. 
- 
        Set the focus on the desired control. 
 
    
    
      
    
    This service provides a number of methods related to the translation of strings with minimal impact on the program's source code. The methods provided by the L10N service can be used mainly to:
    
 
    
    
      
    
  El servicio Platform ofrece una colección de propiedades sobre el entorno y el contexto de ejecución actuales, tales como:
  
      - 
          La plataforma de hárdwer (arquitectura, número de CPU, tipo de equipo, etc.) 
- 
          Información sobre el sistema operativo (tipo de SO, versión, etc.) 
- 
          La versión de LibreOffice 
- 
          El nombre de usuario actual 
 
    
    
      
    
    The PopupMenu service can be used to create popup menus that can be associated with events or executed by scripts. This service provides the following capabilities:
    
      - 
        Creation of popup menus with custom entries, checkboxes and radio buttons. 
- 
        Decoration of menu items with icons and tooltips. 
 
    
    
      
  
  
  The main purpose of the Services module is to provide access to the CreateScriptService method, which can be called in user scripts to instantiate services that are implemented using the ScriptForge framework.
 
    
    
      
    
    
    El servicio Session reúne varios métodos de uso general relativos a:
    
   
    
    
      
  
  The String service provides a collection of methods for string processing. These methods can be used to:
  
    - 
      Validate the contents of strings 
- 
      Format strings by trimming, justifying or wrapping their contents 
- 
      Utilizar expresiones regulares para encontrar y sustituir subcadenas 
- 
      Apply hash algorithms on strings, etc. 
 
    
    
      
  
  The TextStream service is used to sequentially read from and write to files opened or created using the ScriptForge.FileSystem service.
  The methods OpenTextFile and CreateTextFile from the FileSystem service return an instance of the TextStream service.
 
    
    
      
  
  El servicio Timer mide el intervalo de tiempo necesario para ejecutar secuencias de órdenes de usuario.
  A Timer measures durations. It can be:
  
    - 
      Started, to indicate when to start measuring time. 
- 
      Suspended, to pause measuring running time. 
- 
      Resumed, to continue tracking running time after the Timer has been suspended. 
- 
      Restarted, which will cancel previous measurements and start the Timer at zero. 
 
    
    
      
   
The UI (User Interface) service simplifies the identification and the manipulation of the different windows composing the whole LibreOffice application:
   - 
      Selección de ventanas 
- 
      Redimensionamiento y traslado de ventanas 
- 
      Configuración de la barra de estado 
- 
      Presentación de una barra de progreso flotante 
- 
      Creación de ventanas nuevas 
- 
      Acceso a los «documentos» subyacentes 
 
    
    
    Nota: los otros módulos de ScriptForge que no se describen aquí están reservados para uso interno. Su contenido está sujeto a cambios sin previo aviso.
    
      
Todas las rutinas o identificadores BASIC de ScriptForge precedidas por guion bajo «_» están reservadas para uso interno. No deben utilizarse en macros BASIC o secuencias Python.