🙏 Helfen Sie jetzt mit, unser LibreOffice Forum zu erhalten! 🙏
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀

❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Recalculate funktioniert nicht bei Macro mit Parametern

Alles zur Programmierung im LibreOffice.
Antworten
Torben
Beiträge: 2
Registriert: Do 16. Jul 2015, 13:08

Recalculate funktioniert nicht bei Macro mit Parametern

Beitrag von Torben » Do 16. Jul 2015, 13:21

Hallo,

folgende Beispiel-Funktion updated nur beim Start des Dokuments:

Code: Alles auswählen

Function FUN(a as integer, b as integer) as Array

dim feld(2,0)

feld(0, 0) = a
feld(1, 0) = b

FUN = feld
End Function
Was hab ich bisher probiert:
  • Änderung der Eingabezellen ändert nichts (manchmal scheint es einmalig zu klappen)
  • F9/Strg+Shift+F9 ändert nichts
  • Autocalculate ist an
  • Mit Sheet-Events kam nichts Schönes raus
  • Mit Google hab ich noch nichts gefunden
  • Selbst wenn ich die Funktion Fun ein weiteres mal in das Sheet einbaue, werden alte Werte angezeigt
  • Verwende LibreOffice 3.5.7.2 (in 4.4.2.2 war es aber das selbe)
Was mach ich falsch? Oder ist das nur ein kleiner LibreOffice Bug?

Danke schon mal für die Hilfe,
Torben

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2540
Registriert: Fr 10. Dez 2010, 10:01

Re: Recalculate funktioniert nicht bei Macro mit Parametern

Beitrag von karolus » Do 16. Jul 2015, 15:07

Gehts wirklich nur darum einzelne per Zellreferenz übergebene Argumente als (Spalten)array zurückzugeben?

Folgendes funktioniert hier:
In der Standardbibliothek des !Dokuments!

Code: Alles auswählen

Function calculate(a, b)
	on error resume next
    sURL = "vnd.sun.star.script:abc.py$calculate?language=Python&location=user"
    oSP = ThisComponent.getScriptProvider()
    oScript = oSP.getScript(sURL)

    calculate = oScript.invoke(Array(a, b), Array(), Array())
End Function
In deiner ~$(Benutzerkonfiguration)/Scripts/python.abc.py

Code: Alles auswählen

import uno
wrapper = uno.createUnoStruct('com.sun.star.script.ArrayWrapper')

def calculate(a,b):
    wrapper.Array = ((a,),(b,))
    return wrapper
aus dem Calcdokument aufrufen mit

Code: Alles auswählen

=calculate(A1;D4)
als Arrayformel
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

Torben
Beiträge: 2
Registriert: Do 16. Jul 2015, 13:08

Re: Recalculate funktioniert nicht bei Macro mit Parametern

Beitrag von Torben » Do 16. Jul 2015, 16:19

Hi Karolus,

danke für die schnelle Antwort.

In meiner Funktion passiert schon noch mehr, aber der Fehler tritt schon bei dem kleinen Bsp auf.
Weißt du, warum das mit dem Recalculate nicht klappt?

Ich werd mir deinen Vorschlag morgen mal ansehen.

- Torben

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2540
Registriert: Fr 10. Dez 2010, 10:01

Re: Recalculate funktioniert nicht bei Macro mit Parametern

Beitrag von karolus » Do 16. Jul 2015, 17:16

Hallo
Weißt du, warum das mit dem Recalculate nicht klappt?
k.A. vermutlich weil Basic sowieso kaputt ist, halte dich nicht der Fehlersuche auf, verwende eine Lösung wie bereits gepostet, oder schreibe gleich richtige Calc-addins*** ( letzteres bedeutet zunächst mal ein Haufen initialen Lernaufwand, aber am Ende kommt was vernünftiges raus )

***http://www.biochemfusion.com/doc/Calc_addin_howto.html
http://de.openoffice.info/viewtopic.php?f=25&t=60394
https://forum.openoffice.org/en/forum/v ... 21&t=56916
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten