Pomoč LibreOfficeDev 7.6
Knjižnica SFDocuments vsebuje metode in lastnosti, ki lajšajo upravljanje in ravnanje z dokumenti LibreOfficeDev.
Metode, ki veljajo za vse vrste dokumentov (besedilne dokumente, preglednice, predstavitve itn.) so vključene v storitev SFDocuments.Document. Nekaj primerov:
Odpiranje, zapiranje in shranjevanje dokumentov
Dostop do standardnih lastnosti ali lastnosti po meri dokumentov
Lastnosti, metode in argumenti, označeni z zvezdico (*) NE veljajo za dokumente Base.
Metode in lastnosti, specifične za določen modul LibreOfficeDev, se hranijo v ločenih storitvah, kot sta SFDocuments.SF_Calc in SFDocuments.SF_Base.
Čeprav jezik Basic ne ponuja dedovanja med razredi predmetov, lahko slednje storitve štejemo za podrazrede storitve SFDocuments.Document. Takšni podrazredi lahko prikličejo lastnosti in metode, ki so opisani v nadaljevanju.
Pred uporabo storitve Document je potrebno naložiti ali uvoziti knjižnico ScriptForge:
Spodaj so trije načini, kako lahko prikličete storitev Document.
Z uporabo metode getDocument iz storitve ScriptForge.UI:
    Dim ui As Object, oDoc As Object
    Set ui = CreateScriptService("UI")
    Set oDoc = ui.GetDocument("Untitled 1")
  Namesto tega lahko uporabite metodi CreateDocument in OpenDocument iz storitve UI.
    Set oDocA = ui.CreateDocument("Calc")
    Set oDocB = ui.OpenDocument("C:\Documents\MyFile.odt")
  Z uporabo imena okna, če je dokument že odprt.
    Dim oDoc As Object
    Set oDoc = CreateScriptService("SFDocuments.Document", "Untitled 1") 'Default = ActiveWindow
  Z uporabo dokumenta, na katerega se sklicuje ThisComponent. To je še posebej uporabno, ko zaganjate makro iz razvojnega okolja IDE za Basic.
    Dim oDoc As Object
    Set oDoc = CreateScriptService("Document", ThisComponent)
  Iz makra, ki ga proži dogodek dokumenta.
    Sub RunEvent(ByRef poEvent As Object)
        Dim oDoc As Object
        Set oDoc = CreateScriptService("SFDocuments.DocumentEvent", poEvent)
        ' (...)
    End Sub
  Storitev Document je tesno povezana s storitvama UI in FileSystem.
Če dokumenta ni zaprl program z metodo CloseDocument (sicer je ta napotek odveč), priporočamo, da po uporabi sprostite vire:
    Set oDoc = oDoc.Dispose()
  
    from scriptforge import CreateScriptService
    ui = CreateScriptService("UI")
    doc = ui.GetDocument("Untitled 1")
    # (...)
    doc.Dispose()
  
    docA = ui.CreateDocument("Calc")
    docB = ui.OpenDocument("C:\Documents\MyFile.odt")
  
    doc = CreateScriptService("SFDocuments.Document", "Untitled 1")
  
    bas = CreateScriptService("Basic")
    doc = CreateScriptService("Document", bas.ThisComponent)
  
    def RunEvent(event)
        doc = CreateScriptService("SFDocuments.DocumentEvent", Event)
        # (...)
  Uporaba predpone »SFDocuments.« pri klicu storitve je neobvezna.
| Ime | Samo za branje | Vrsta | Opis | 
|---|---|---|---|
| CustomProperties (*) | Ne | Dictionary service | Vrne instanco predmeta ScriptForge.Dictionary. Po posodobitvi ga lahko znova podate lastnosti za posodobitev dokumenta. | 
| Description (*) | Ne | String | Nudi dostop do opisa dokumenta (lastnost Description), znano tudi pod nazivom Komentarji (angl. "Comments") | 
| DocumentProperties (*) | Da | Dictionary service | Vrne predmet ScriptForge.Dictionary, ki vsebuje vse vnose. Statistika dokumenta je vključena. Upoštevajte, da se glede na vrsto dokumentov razlikuje. Primer: dokument programa Calc vsebuje vnos "CellCount", torej števec celic. Druge vrste dokumentov tega vnosa nimajo. | 
| DocumentType | Da | String | Vrednost niza z vrsto dokumenta ("Base", "Calc", "Writer" itn.) | 
| ExportFilters | Da | String array | Vrne seznam z imeni izvoznih filtrov, ki jih je moč uporabiti za trenutni dokument, kot ničelno polje nizov. Vrne tudi filtre, uporabljene tako za uvoz kot izvoz. | 
| ImportFilters | Da | String array | Vrne seznam z imeni uvoznih filtrov, ki jih je moč uporabiti za trenutni dokument, kot ničelno polje nizov. Vrne tudi filtre, uporabljene tako za uvoz kot izvoz. | 
| IsBase | Da | Boolean | Natanko ena od teh lastnosti je enaka True za dani dokument. | 
| Keywords (*) | Ne | String | Nudi dostop do ključnih besed dokumenta (lastnost Keywords). Predstavljen v obliki z vejicami ločenega seznama ključnih besed | 
| Readonly (*) | Da | Boolean | True, če je dokument dejansko v načinu samo za branje | 
| Subject (*) | Ne | String | Nudi dostop do zadeve dokumenta (lastnost Subject). | 
| Title (*) | Ne | String | Nudi dostop do naslova dokumenta (lastnost Title). | 
| XComponent | Da | Predmet UNO | Predmet UNO com.sun.star.lang.XComponent ali com.sun.star.comp.dba.ODatabaseDocument, ki predstavlja dokument | 
Spodnji primer izpiše vse lastnosti dokumenta. Upoštevajte, da je predmet oDoc, ki ga vrne metoda UI.OpenDocument, predmet SFDocuments.Document.
    Dim ui as Variant : Set ui = CreateScriptService("UI")
    Dim oDoc as Object
    Set oDoc = ui.OpenDocument("C:\Documents\MyFile.ods")
    Dim propDict as Object
    Set propDict = oDoc.DocumentProperties
    Dim keys as Variant : propKeys = propDict.Keys
    Dim k as String, strProp as String
    For Each k In propKeys
        strProp = strProp & k & ": " & propDict.Item(k) & CHR$(10)
    Next k
    MsgBox strProp
    oDoc.CloseDocument()
  Če želite dostopati do lastnosti dokumenta v skriptu Python, morate neposredno dostopati z rabo njihovih imen, kot je prikazano spodaj:
    doc = ui.GetDocument(r"C:\Documents\MyFile.ods")
    msg = doc.Title + '\n' + doc.Description + '\n' + doc.Keywords
    bas = CreateScriptService("Basic")
    bas.MsgBox(msg)
    doc.CloseDocument()
  | Seznam metod storitve Document | ||
|---|---|---|
Vrne True, če je aktivacija dokumenta uspela. Sicer v dejanskem uporabniškem vmesniku ni sprememb. Je enakovredna metodi Activate storitve UI.
Ta metoda je uporabna, ko želite pozornost usmeriti na dokument, ki je pomanjšan ali skrit.
svc.Activate(): bool
Spodnji primer predvideva, da je datoteka "My_File.ods" že odprta, vendar ni aktivna.
    Dim oDoc As Object
    Set oDoc = CreateScriptService("Document", "MyFile.ods")
    oDoc.Activate()
  
    doc = CreateScriptService("Document", "MyFile.ods")
    doc.Activate()
  Upoštevajte, da lahko prikličete storitev Document s podajanjem "Document" ali "SFDocuments.Documentby" k CreateScriptService.
Zapre dokument. Če je dokument že zaprt (ne glede na to, kako je bil zaprt), ta metoda nima učinka in vrne False.
Ta metoda vrne False, če uporabnik zavrne njeno zaprtje.
Vrne True, če je bil dokument uspešno zaprt.
svc.CloseDocument(saveask: bool = True): bool
saveask: če je enako True (privzeto), povpraša uporabnika, da potrdi, ali naj se spremembe shranijo na disk. Ta argument je prezrt, če dokument ni bil spremenjen.
    If oDoc.CloseDocument(True) Then
        ' ...
    End If
  
    if doc.CloseDocument(True):
        # ...
  Ustvari nov menijski vnos v menijski vrstici danega okna dokumenta.
Ta metoda vrne instanco storitve SFWidgets.Menu.
Ustvarjeni meni je na voljo le med trenutno sejo LibreOfficeDev in se ne shrani niti v dokument, niti med splošne nastavitve programa. Zato z zaprtjem okna programa meni izgine. Ponovno se pojavi, ko se makro, ki ustvari meni, ponovno izvrši.
svc.CreateMenu(menuheader: str, [before: any], submenuchar: str = ">"): svc
menuheader: vrhnje ime novega menija.
before: ime (kot niz) ali položaj (kot celo število, od 1 naprej) obstoječega menija, pred katerega bo postavljen nov meni. Če za ta argument vrednost ni določena, bo meni ustvarjen na zadnjem mestu v menijski vrstici.
submenuchar: ločilo za ustvarjanje menijskih dreves pri klicu metod, kot je AddItem v storitvi Menu. Privzeta vrednost je »>«.
    Dim oDoc as Object, oMenu as Object
    Set oDoc = CreateScriptService("Document")
    Set oMenu = oDoc.CreateMenu("Moj meni")
    With oMenu
        ' Dodaj elemente v meni
        .AddItem("Item A")
        .AddItem("Item B")
        ' ...
        ' Po izdelavi menija se lahko znebimo instance storitve
        .Dispose()
    End With
  
    doc = CreateScriptService("Document")
    menu = doc.CreateMenu("Moj meni")
    menu.AddItem("Item A")
    menu.AddItem("Item B")
    # ...
    menu.Dispose()
  Oglejte si stran pomoči SFWidgets.Menu, da izveste več o tem, kako ustvarjati/odstranjevati menije v oknih dokumentov LibreOfficeDev.
Neposredno izvozi dokument kot datoteko PDF na navedeno mesto. Vrne True, če je bila datoteka PDF uspešno ustvarjena.
Izvozne možnosti lahko določite ročno prek pogovornega okna ali s klicem metod GetPDFExportOptions in SetPDFExportOptions iz storitve Session.
svc.ExportAsPDF(filename: str, overwrite: bool = False, opt pages: str, opt password: str, opt watermark: str): bool
filename: polna pot in ime datoteke PDF, ki jo želite ustvariti. Slediti mora zapisu SF_FileSystem.FileNaming.
overwrite: določa, ali je ciljno datoteko možno prepisati (privzeta vrednost je False). Če je overwrite nastavljen na False in ciljna datoteka že obstaja, pride do napake.
pages: niz, ki določa, katere strani bodo izvožene. Ta argument uporablja isto obliko zapisa kot v pogovornem oknu .
password: določa geslo za odpiranje datoteke PDF.
watermark: besedilo, ki naj bo uporabljeno v datoteki PDF za vodni žig, ki bo izrisan na vsaki strani končnega PDF.
Naslednji primer izvozi trenutni dokument v datoteko PDF, določi geslo in prepiše ciljno datoteko, če že obstaja.
    oDoc.ExportAsPDF("C:\User\Documents\myFile.pdf", Password := "1234", Overwrite := True)
  Spodnji odlomek kode pridobi trenutne izvozne možnosti za PDF in jih uporabi za ustvarjanje datoteke PDF.
    Dim exportSettings as Object, oSession as Object
    oSession = CreateScriptService("Session")
    exportSettings = oSession.GetPDFExportOptions()
    ' Možnost izvoza komentarjev kot opomb PDF nastavi na True
    exportSettings.ReplaceItem("ExportNotes", True)
    oSession.SetPDFExportOptions(exportSettings)
    oDoc.ExportAsPDF("C:\User\Documents\myFile.pdf")
  
    doc.ExportAsPDF(r"C:\User\Documents\myFile.pdf", password = "1234", overwrite = True)
  
    session = CreateScriptService("Session")
    exportSettings = oSession.GetPDFExportOptions()
    exportSettings.ReplaceItem("ExportNotes", True)
    session.SetPDFExportOptions(exportSettings)
    doc.ExportAsPDF(r"C:\User\Documents\myFile.pdf")
  Ta metoda pošlje vsebino dokumenta privzetemu tiskalniku ali tiskalniku, ki ga določa metoda SetPrinter.
Vrne True, če je bil dokument uspešno natisnjen.
svc.PrintOut(pages: str = "", copies: num = 1): bool
pages: strani, ki jih želite natisniti, kot niz, tako kot v uporabniškem vmesniku. Primer: »1-4;10;15-18«. Privzeta vrednost je tiskanje vseh strani.
copies: število kopij. Privzeto ima vrednost 1.
    If oDoc.PrintOut("1-4;10;15-18", Copies := 2) Then
        ' ...
    End If
  
    if doc.PrintOut(copies=3, pages='45-88'):
        # ...
  Odstrani vrhnji meni iz menijske vrstice danega okna dokumenta.
Vrne True, če je navedeni meni uspešno odstranjen. Če navedeni meni ne obstaja, metoda vrne False.
S to metodo lahko odstranite poljuben menijski vnos iz okna dokumenta, vključno s tistimi v privzetih menijih. Vendar pa se nobena od teh sprememb v menijski vrstici ne shrani v dokument ali nastavitve programa. Če želite obnoviti menijsko vrstico na privzete nastavitve, enostavno zaprite in ponovno odprite okno dokumenta.
svc.RemoveMenu(menuheader: str): bool
menuheader: vrhnje ime menija, ki naj bo odstranjen.
    Dim oDoc as Object
    Set oDoc = CreateScriptService("Document")
    oDoc.RemoveMenu("Moj meni")
  
    doc = CreateScriptService("Document")
    doc.RemoveMenu("Moj meni")
  Zažene ukaz UNO v oknu dokumenta, povezanim z instanco storitve. Nekaj tipičnih ukazov: Save (Shrani), SaveAs (Shrani kot), ExportToPDF (IzvoziVPDF), Undo (Razveljavi), Copy (Kopiraj), Paste (Prilepi) itn.
Sam dokument ne rabi biti aktiven, da bi lahko izvedli ukaze.
Ukazi se lahko zaženejo z ali brez argumentov. Argumenti se ne preverjajo pred izvajanjem ukaza. Če so ukaz ali njegovi argumenti neveljavni, se ne zgodi nič.
Celoten seznam ukazov UNO, ki jih lahko izvajate v LibreOfficeDev, si oglejte na wiki-strani Development/DispatchCommands (v angl.).
svc.RunCommand(command: str, [args: any])
command: niz, ki vsebuje ime ukaza UNO. Vklučenost predpone ».uno:« ni obvezna. Sama pravilnost ukaza se ne preverja. Če se po klicu ukaza ne zgodi nič, je z ukazom oz. njegovim klicem najbrž nekaj narobe.
args: za vsak argument, ki bo posredovan ukazu, navedite par, ki vsebuje ime argumenta in njegovo vrednost.
Naslednji primer izvede ukaz SelectData na delovnem listu preglednice programa Calc z imenom »MyFile.ods«, ki vrne izbor območja podatkov glede na položaj trenutno izbrane celice. Upoštevajte, da ta ukaz ne zahteva nobenih argumentov.
    Set oDoc = CreateScriptService("Document", "MyFile.ods")
    oDoc.RunCommand("SelectData")
  Spodaj je primer, ki zažene ukaz UNO ReplaceAll in poda vrednosti za njegove argumente SearchString in ReplaceString. Izvajanje tega ukaza zamenja vse pojavitve niza »abc« z »ABC« na trenutnem delovnem listu.
    ' Argumenti, posredovani ukazu:
    ' SearchString  = "abc"
    ' ReplaceString = "ABC"
    oDoc.RunCommand(".uno:ReplaceAll", "SearchString", "abc", "ReplaceString", "ABC")
  Upoštevajte, da klic ukaza ReplaceAll brez argumentov odpre pogovorno okno .
    doc = CreateScriptService("Document", "MyFile.ods")
    doc.RunCommand("SelectData")
  
    doc.RunCommand(".uno:ReplaceAll", "SearchString", "abc", "ReplaceString", "ABC")
  V Pythonu lahko pokličete tudi RunCommand z argumenti ključnih besed:
    doc.RunCommand(".uno:ReplaceAll", SearchString = "abc", ReplaceString = "ABC")
  Vsak program paketa LibreOfficeDev ima na voljo lasten nabor ukazov. Enostaven način spoznavanja takšnih ukazov je priklic okna Orodja – Prilagodi – Tipkovnica. Ko postavite miško nad funkcijo na seznamu Funkcija, se pojavi namig z ustreznim ukazom UNO.
Shrani dokument na datotečno mesto, s katerega je bil naložen. Metoda je prezrta, če dokument ni bil spremenjen.
Vrne False, če je shranjevanje dokumenta spodletelo. Če je datoteka odprta samo za branje ali če gre za novo datoteko, ki še ni bila shranjena, prikliče napako.
Sam dokument ne rabi biti aktiven, da bi lahko izvedli to metodo.
svc.Save(): bool
    If Not oDoc.Save() Then
        ' ...
    End If
  
    if not doc.Save():
        # ...
  Shrani dokument na podano datotečno mesto. Novo mesto postane novo ime datoteke, nad katerim bodo uveljavljeni enostavni klici metode Save (Shrani).
Vrne False, če je shranjevanje dokumenta spodletelo. Prikliče napako, če je prepis cilja zavrnjen ali če ima cilj določen atribut samo za branje.
Sam dokument ne rabi biti aktiven, da bi lahko izvedli to metodo.
svc.SaveAs(filename: str, overwrite: bool = False, password: str = '', filtername: str = '', filteroptions: str = ''): bool
filename: niz, ki vsebuje ime datoteke, ki ga želite uporabiti. Slediti mora zapisu SF_FileSystem.FileNaming.
overwrite: če je True, je ciljno datoteko možno prepisati (privzeto = False).
password (*): niz brez presledkov za geslo, s katerim zaščitite dokument.
filtername (*): ime filtra, ki naj bo uporabljen za shranjevanje dokumenta. Če ta argument podate, mora filter obstajati.
filteroptions (*): neobvezen niz možnosti, povezanih s filtrom.
    oDoc.SaveAs("C:\Documents\NewCopy.odt", overwrite := True)
  
    doc.SaveAs(r"C:\Documents\NewCopy.odt", overwrite = True)
  Shrani kopijo ali izvoženi dokument na podano mesto shranjevanja. Dejansko mesto hrambe ostane nespremenjeno.
Vrne False, če je shranjevanje dokumenta spodletelo. Prikliče napako, če je prepis cilja zavrnjen ali če ima cilj določen atribut samo za branje.
Sam dokument ne rabi biti aktiven, da bi lahko izvedli to metodo.
svc.SaveCopyAs(filename: str, overwrite: bool = False, password: str = '', filtername: str = '', filteroptions: str = ''): bool
filename: niz, ki vsebuje ime datoteke, ki ga želite uporabiti. Slediti mora zapisu SF_FileSystem.FileNaming.
overwrite: če je True, je ciljno datoteko možno prepisati (privzeto = False).
password (*): niz brez presledkov za geslo, s katerim zaščitite dokument.
filtername (*): ime filtra, ki naj bo uporabljen za shranjevanje dokumenta. Če ta argument podate, mora filter obstajati.
filteroptions (*): neobvezen niz možnosti, povezanih s filtrom.
    oDoc.SaveCopyAs("C:\Documents\Copy2.odt", Overwrite := True)
  
    doc.SaveCopyAs(r"C:\Documents\Copy2.odt", overwrite = True)
  Določi možnosti tiskanja za dokument.
Vrne True, če uspe.
svc.SetPrinter(opt printer: str, opt orientation: str, paperformat: str): bool
printer: ime tiskalniške vrste, kamor želite tiskati. Če ta argument manjka, je nastavljen privzeti tiskalnik.
orientation določa postavitev strani in ima dve možni vrednosti: PORTRAIT (pokončno) in LANDSCAPE (ležeče). Če argument ni podan, ostane nespremenjen glede na nastavitve tiskalnika.
paperformat: določa velikost strani oz. papirja kot niz in ima možne vrednosti A3, A4, A5, LETTER, LEGAL ali TABLOID. Če argument ni podan, ostane nespremenjena privzeta vrednost.
    oDoc.SetPrinter(Orientation := "PORTRAIT")
  
    doc.SetPrinter(paperformat='TABLOID')