Aide Collabora Office 24.04
Les scripts Python de Collabora Office se dĂ©clinent en trois versions distinctes, ils peuvent ĂȘtre personnels, partagĂ©s ou intĂ©grĂ©s dans des documents. Ils sont stockĂ©s Ă diffĂ©rents endroits dĂ©crits dans Python Scripts Organization and Location. Afin d'importer des modules Python, leurs emplacements doivent ĂȘtre connus depuis Python au moment de l'exĂ©cution.
Ce mécanisme est illustré pour les modules basés sur le systÚme de fichiers et les modules basés sur les documents. La gestion des exceptions est omise par souci de clarté. Les termes bibliothÚque ou répertoire, scripts ou modules sont utilisés de maniÚre interchangeable. Une macro Python fait référence à une fonction dans un module.
Notez que <User Profile>/Scripts/python/pythonpath répertoire local est toujours exploré lors de l'exécution d'une macro Python de <User Profile>/Scripts/python.
Les scripts Python personnels et partagĂ©s peuvent ĂȘtre importĂ©s une fois que leurs rĂ©pertoires sont inclus dans le chemin d'exĂ©cution Python. Reportez-vous Ă la page Obtenir des informations de session pour plus de dĂ©tails sur la classe de session omise.
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import sys
user_lib = Session().UserPythonScripts # emplacement des scripts utilisateur
if not user_lib in sys.path:
sys.path.insert(0, user_lib) # Ajouter au chemin de recherche
import screen_io as ui # le module 'screen_io.py' module réside dans le répertoire user_lib
# Votre code suit ici
Cet exemple Python expose une variable XSCRIPTCONTEXT locale à un module importé :
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import uno, sys
share_lib = Session.SharedPythonScripts() # Emplacement des scripts partagés
if not share_lib in sys.path:
sys.path.insert(0, share_lib) # Ajouter au chemin de recherche
from IDE_utils import ScriptContext # IDE_utils.py' se trouve avec les scripts Python partagés.
XSCRIPTCONTEXT = ScriptContext(uno.getComponentContext)
# Votre code suit ici
Contrairement aux scripts personnels et partagĂ©s, les scripts d'installation de Collabora Office peuvent ĂȘtre importĂ©s Ă tout moment. Ă cĂŽtĂ© des modules Collabora Office Python uno & unohelper, les autres scripts prĂ©sents dans le rĂ©pertoire <installation_path>/program peuvent ĂȘtre importĂ©s directement, comme le module msgbox.
Avec le shell Python :
>>> import msgbox, uno
>>> myBox = msgbox.MsgBox(uno.getComponentContext())
>>> myBox.addButton("okay")
>>> myBox.renderFromButtonSize()
>>> myBox.numberOflines = 2
>>> print(myBox.show("A small message",0,"Dialog title"))
L'import d'un module Python intégré au document est illustrée ci-dessous. La gestion des erreurs n'est pas détaillée. Le chemin d'exécution Python est mis à jour à l'ouverture du document et avant sa fermeture. Voir Event-Driven Macros pour savoir comment associer des macros Python pour documenter des événements.
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import sys, uno
def OnDocPostOpenLoadPython():
""" Prepare l'import des modules Python pendant que le doc. charge """
PythonLibraries.loadLibrary('lib/subdir') # Ajoute le dossier au chemin de recherche
PythonLibraries.loadLibrary('my_gui', 'screen_io') #Ajoute le répertoire & importe screen_io
def OnDocQueryCloseUnloadPython():
""" Nettoie PYTHON_PATH quand doc.fermé """
PythonLibraries.unloadLibrary('my_gui') # Python runtime path cleanup
# Note: les modules importés restent chargés dans cet exemple
class PythonLibraries():
""" chargeur de bibliothĂšque Python et importation de modules
adapté depuis'BibliothÚque de fonctions' parHubert Lambert
Ă https://forum.openoffice.org/fr/forum/viewtopic.php?p=286213 """
def isImportedModule(module_name: str) -> bool:
""" Check run time module list """
return (module_name in sys.modules.keys())
def isLoadedLibrary(lib_name: str) -> bool:
""" VĂ©rifie le contenu de PYTHON_PATH """
return (lib_name in sys.path)
def loadLibrary(lib_name: str, module_name=None):
""" ajoute le répertoire à PYTHON_PATH, importe le module nommé"""
doc = XSCRIPTCONTEXT.getDocument()
url = uno.fileUrlToSystemPath(
'{}/{}'.format(doc.URL,'Scripts/python/'+lib_name)
if not url in sys.path:
sys.path.insert(0, url)
if module_name and not module_name in sys.modules.keys():
return zipimport.zipimporter(url).load_module(module_name)
def unloadLibrary(lib_name: str):
"""supprime le répertoire de PYTHON_PATH """
sys.path.remove(lib_name)
g_exportedScripts = (OnDocPostOpenLoadPython, OnDocQueryCloseUnloadPython)