🙏 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. 🤗

[GELÖST]Fehler in Klammer?

Alles zur Programmierung im LibreOffice.
Antworten
Mike_S
Beiträge: 14
Registriert: Fr 15. Jan 2021, 13:08
Wohnort: Flensburg
Kontaktdaten:

[GELÖST]Fehler in Klammer?

Beitrag von Mike_S » Mi 2. Feb 2022, 11:20

Moin zusammen!

Ich habe hier eine Tabelle, in der in mehreren Spalten Werte stehen, bei denen ich den höchsten Wert ermitteln möchte.

Ich dachte mir, ich könnte dazu die Funktion MAX nutzen, die ja "eigentlich" für sowas vorgesehen ist.

Im Makro sieht das bei mir so aus:
dim Testvar as integer

Testvar = MAX(oSheet.getCellRangebyName("$" & SP_Gesamtpunkte_Ausdauer & "$" & Z_Eingabe).value; oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_Dauerlauf & "$" & Z_Eingabe).value; oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_3000_m_Lauf & "$" & Z_Eingabe).value; oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_10_km_Lauf & "$" & Z_Eingabe).value; oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_Schwimmen & "$" & Z_Eingabe).value;oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_Radfahren & "$" & Z_Eingabe).value;oSheet.getCellRangebyName("$" & SP_Punkte_Ausdauer_Walking & "$" & Z_Eingabe).value)
Wenn ich das Makro dann laufen lasse, dann bekomme ich die Rückmeldung "BASIC-Syntaxfehler.
Fehler in Klammerschachtelung."

Das sieht für meinen Geschmack aber korrekt aus.: Alle geöffneten Klammer werden auch wieder geschlossen. Rufe ich die Funktion vielleicht falsch auf, so dass es zu dieser (für mich dann irreführenden) Fehlermeldung kommt?

Gruß,

Mike
Zuletzt geändert von Mike_S am Mi 2. Feb 2022, 13:14, insgesamt 1-mal geändert.

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

Re: Fehler in Klammer?

Beitrag von karolus » Mi 2. Feb 2022, 12:39

Hallo

Basic ist halt kein Wunschkonzert.
  • es kennt keine Funktion max
  • Argumente werden in Basic per Komma getrennt nicht per Semicolon…
  • … und müssen vorher per array-function in eine Liste gewandelt werden
  • Deine $zeichen sind im kontext völlig überflüssig
funktionierendes Beispiel:

Code: Alles auswählen

sub printmax
    doc = thisComponent
    osheet = doc.Sheets(0)
    foo =  createUnoService("com.sun.star.sheet.FunctionAccess")
    testvalues = array(oSheet.getCellRangebyName("A1").value,_
        oSheet.getCellRangebyName("A2").value,_
        oSheet.getCellRangebyName("A3").value,_
        oSheet.getCellRangebyName("A4").value,_
        oSheet.getCellRangebyName("A6").value,_
        oSheet.getCellRangebyName("A7").value,_
        oSheet.getCellRangebyName("A8").value)
  m = foo.callFunction("max",testvalues)
  print m
end sub
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

Mike_S
Beiträge: 14
Registriert: Fr 15. Jan 2021, 13:08
Wohnort: Flensburg
Kontaktdaten:

Re: Fehler in Klammer?

Beitrag von Mike_S » Mi 2. Feb 2022, 13:14

Hi Karolus!

Danke für Deine Hinweise... Ich vermute mal, einiges liegt daran, dass ich noch in VBA "gefangen" bin... ;)

Auf jeden Fall läuft es jetzt!

Danke und Gruß,

Mike


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