Collabora Office 24.04 Help
De bibliotheek ScriptForge is zowel in Basic als in Python beschikbaar. De meeste services, methoden en eigenschappen werken in beide programmeertalen gelijk. Maar, er zijn natuurlijk wel wat verschillen hoe de talen werken. Als u in Python ScriptForge gebruikt, let dan op het volgende:
Namen van methoden en eigenschappen: In Python, kunnen deze namen de opmaken lowercased, ProperCased en camelCased hebben.
Argumenten: Alle sleutelwoord argumenten voor methoden zijn met kleine letters.
Datums: Alle objecten die een datum zijn worden doorgegeven en ontvangen als datetime.datetime Python-objecten.
Matrices: Een eendimensionale matrix wordt doorgegeven en ontvangen als een tuple (dat is een object dat niet te wijzigen is). Een tweedimensionale matrix als een tuple van tuples.
None: Het Python sleutelwoord None is gelijkwaardig aan Basic's Null, Empty en Nothing.
UNO-objecten: Alle UNO-structuren zijn tussen Python en Basic uitwisselbaar.
Debuggen: Als er in een Python-script, dat ScriptForge gebruikt, een fout optreedt dan is er op de stack een foutboodschap beschikbaar met de regel in de code waar de fout is opgetreden. In Basic is dit regelnummer niet beschikbaar.
Meer informatie vind u op Hulp bij Collabora Office Python-scripts over het gebruik van Python scripts in Collabora Office.
Afhankelijk van wat u wilt bereiken, kunt u kiezen uit de volgende aanpakken om Python-scripts in Collabora Office uit te voeren:
Scripts uitvoeren binnen het huidige proces Collabora Office: Python-scripts worden uitgevoerd binnen het Collabora Office proces door te kiezen of door de extensie APSO te gebruiken om een gebruikersscript in de map met Python-scripts aan te roepen. U kunt ook de APSO Python-shell gebruiken om interactief Python-scripts uit te voeren.
Scripts kunnen ook buiten het Collabora Office proces worden uitgevoerd: Python-scripts worden uitgevoerd door een extern proces dat verbinding maakt met het lopende Collabora Office proces via een socket.
Indien u scripts binnen het Collabora Office proces wilt gaan uitvoeren, dan bevelen wij aan om de extensie APSO (Alternative Script Organizer for Python) te installeren. Als u echter uw Python-scripts buiten Collabora Office wilt gaan ontwerpen, kies dan uw favoriete Python IDE.
De gemakkelijkste manier om met Python-scripts in Collabora Office te beginnen is het gaan werken met de extensie APSO. Ga, na het installeren, in een Collabora Office component naar
.Ga in het hoofdscherm van APSO naar
.U kunt APSO ook openen met de sneltoets Alt + Shift + F11.
Nu kunt u beginnen met het invoeren van Python-commando's, in de shell wordt dan na uitvoering de uitvoer getoond.
Voordat u de bibliotheek ScriptForge kunt gebruiken moet u eerst de methode CreateScriptService importeren, daarna kunt u via deze methode de services in de bibliotheek benaderen. In dit voorbeeld gebruiken we de service in Basic om een berichtvenster te tonen.
from scriptforge import CreateScriptService
bas = CreateScriptService("Basic")
bas.MsgBox("Hello!")
Om dit in de Python-shell uit voeren moet u de tekst regel voor regel invoeren en elke regel afsluiten met de Enter-toets.
Nu kunt u beginnen met het uitvoeren van Python-commando's met gebruik van een van de services in ScriptForge. U kunt bijvoorbeeld met de code hieronder de service UI gebruiken om een Writer-document aan te maken.
ui = CreateScriptService("UI")
doc = ui.CreateDocument("Writer")
U kunt uw eigen Python-bestanden aanmaken met uw favoriete tekstverwerker. U kunt ze dan later aanroepen in een van de Collabora Office componenten.
De eerste stap is het bepalen waar de gebruikersscripts worden opgeslagen. Hier staat een uitleg.
U kunt nu een tekstbestand in uw Python map voor gebruikersscripts aanmaken, bijvoorbeeld sf_test.py en uw scripts gaan invoeren.
In het volgende eenvoudige voorbeeld verhogen we de numerieke waarde van een cel in Calc met 1. Plaats de volgende code in het bestand sf_test.py.
from scriptforge import CreateScriptService
doc = CreateScriptService("Calc")
def increment_cell(args=None):
value = doc.GetValue("A1")
value += 1
doc.SetValue("A1", value)
g_exportedScripts = (increment_cell, )
Er is nu een functie increment_cell aangemaakt. De g_exportedScripts is een tuple dat aangeeft welke functies zullen worden getoond in Collabora Office als gebruikersscripts.
Om dit script nu in een Calc-document uit te voeren:
Maak of open een Calc-document.
Vul in cel "A1" in het huidige blad een numerieke waarde in.
Ga naar
.Kies in de lijst met bibliotheken Mijn Macro's - sf_test. Kies vervolgens de functie increment_cell in de lijst .
Klik op de knop Uitvoeren. Controleer of de waarde in cel "A1" met 1 is opgehoogd.
U kunt op een vergelijkbare manier APSO gebruiken om een Python-script uit te voeren:
Open eerst APSO via
.Ga in de lijst met macro's naar
.Klik op
.De eerste stap om scripts los uit te voeren is het opzoeken in welke map Collabora Office is geïnstalleerd. Dat kan op verschillende manieren, maar het installatiepad opzoeken kan heel snel via ScriptForge. Open de Python-shell van APSO en voer in:
from scriptforge import CreateScriptService
fs = CreateScriptService("FileSystem")
fs.FileNaming = "SYS"
inst_dir = fs.InstallFolder
print(inst_dir)
De uitvoer van de bovenstaande code is de installatiemap van Collabora Office. Voeg hieraan nog wel de submap "program" toe. Dit is dan de basismap om in een losstaand proces Python-scripts uit te voeren.
Een voorbeeld, als de uitvoer van de code /usr/lib/libreoffice/ was, dan is het benodigde pad dus /usr/lib/libreoffice/program.
Om Python-scripts als een losstaand proces uit te voeren moet Collabora Office worden gestart met twee aanvullende opties die de hostnaam en de poort aangeven die het externe proces gebruikt voor het communiceren met de Collabora Office component.
Open het terminalvenster op uw computer, ga naar de installatiemap van Collabora Office en voer in:
./soffice --accept='socket,host=localhost,port=2021;urp;'
Met bovenstaande commando wordt Collabora Office gestart met een open communicatiekanaal, via dit kanaal kunnen andere processen berichten sturen.
In het voorbeeld wordt Collabora Office geopend maar nog niet een specifieke component. Als u direct Writer wilt openen, voeg dan --writer toe aan het commando.
./soffice --writer --accept='socket,host=localhost,port=2021;urp;'
In dit commando worden met de parameters host en port dus de twee eerder genoemde aanvullende opties doorgegeven, de waarden zijn localhost en 2021.
Open een Python-shell en ga naar de map program van de installatiemap van Collabora Office. Voer de bovenstaande stappen uit om het installatiepad te bepalen.
Op Linux / Mac OS:
$ cd /usr/lib/libreoffice/program
$ python
Op Windows:
$ cd C:\Program Files\LibreOffice\program\
$ python.exe
De Python-shell is nu geopend en u kunt nu dus commando's invoeren en laten uitvoeren door Collabora Office. Met het eerste commando moet u verbinding maken met het socket.
from scriptforge import ScriptForge, CreateScriptService
ScriptForge(hostname='localhost', port=2021)
Lees het gedeelte PYTHONPATH instellen hieronder in geval van fouten bij het importeren van scriptforge.py of uno .py.
Hierboven wordt de instelling van de host en de port gedaan zodat de Python-shell kan communiceren met het Collabora Office proces dat geopend is met deze via deze socket.
Nu kunnen we echt aan de slag met wat u in Collabora Office wilt laten doen. Bijvoorbeeld:
ui = CreateScriptService("UI")
bas = CreateScriptService("Basic")
doc = ui.OpenDocument("~/Documents/myFile.ods")
bas.MsgBox(doc.DocumentType)
Afhankelijk van de configuratie van uw besturingssysteem moet u de omgevingsvariabele PYTHONPATH instellen om de bibliotheek scriptforge.py te importeren, waarvoor u vervolgens de uno. py bibliotheek moet importeren.
Gebruik de bestandszoekfunctie van uw besturingssysteem om de map te bepalen waar beide bestanden zich bevinden.
Bij een standaard Ubuntu-installatie kunnen beide bestanden zich bijvoorbeeld bevinden op:
scriptforge.py: Bevindt zich in /usr/lib/libreoffice/program
uno.py: Bevindt zich in /usr/lib/python3/dist-packages
In dit geval stelt u de omgevingsvariabele PYTHONPATH als volgt in voordat u de Python-interpreter start:
export PYTHONPATH=/usr/lib/libreoffice/program:/usr/lib/python3/dist-packages
De locatie van deze bestanden zal voor elk besturingssysteem en Collabora Office-installatiemethode verschillend zijn.