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

Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

CALC ist die Tabellenkalkulation, die Sie immer wollten.
Antworten
Annika2511
Beiträge: 4
Registriert: Mi 18. Aug 2021, 08:37

Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

Beitrag von Annika2511 » Mi 18. Aug 2021, 08:41

Hallo zusammen,
ich lese in die Zelle A1 eine Nummer mithilfe eines Handscanners ein. Diese Nummer hat immer eine 100 davor stehen (z.B. 100123456). Ich würde nun gerne ein Makro im Dokument hinterlegen, das immer, wenn ich eine Nummer in diese Zelle einlese die 100 zu Beginn automatisch rauschlöscht (also immer die ersten 3 Zeichen).
Könnt ihr mir da weiterhelfen?

Vielen Dank schon mal im Voraus!

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

Re: Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

Beitrag von karolus » Mi 18. Aug 2021, 18:38

Hallo
Frage1: Soll das ausschliesslich in Zelle A1 geschehen?

Frage2: Ist die Eingabe des Scanners eine Zahl oder Text? ( ist die Eingabe blau nach →→Ansicht→→Werte hervorheben ? )


edit:
im angefügtem Beispiel habe ich in Tabelle2 dem Tabellenereigniss Inhalt geändert folgendes Makro zugeordnet:

Code: Alles auswählen

Sub scanner_input(event)
    If right(event.AbsoluteName, 4) = "$A$1" And left(event.Formula, 3) = "100" Then
        event.Formula = mid(event.Formula, 3, len(event.Formula))
    End if
End Sub
Scanner_eingabe_modifizieren.ods
(22.96 KiB) 125-mal heruntergeladen
edit2:
Eine gemischte Eingabe (numerisch|Text) zB 100abc führt mit dem Basiccode oben zu einer Ausgabe von 0abc
der eigentlich äquivalente python-code unten machts richtig: 100abc → abc

Code: Alles auswählen

def input_mod_hundert(event):
    if (event.AbsoluteName.endswith("$A$1")
    and event.Formula.startswith("100")):
        event.Formula = event.Formula[3:]
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

Annika2511
Beiträge: 4
Registriert: Mi 18. Aug 2021, 08:37

Re: Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

Beitrag von Annika2511 » Do 19. Aug 2021, 07:38

Hallo karolus,
vielen Dank schon mal für deine Antwort.
Zu Frage 1: Ja, das soll ausschliesslich in Zelle A1 geschehen
Zu Frage 2: Die Eingabe ist eine Zahl (die Eingabe erscheint blau bei "Werte hervorheben").

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

Re: Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

Beitrag von karolus » Do 19. Aug 2021, 08:45

Hallo
dann funktioniert die Beispielsdatei aus meiner Antwort wie gewünscht ?!
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

Annika2511
Beiträge: 4
Registriert: Mi 18. Aug 2021, 08:37

Re: Nummer nach Eingabe automatisch um die ersten drei Zeichen löschen

Beitrag von Annika2511 » Do 19. Aug 2021, 09:49

Ja, habe es gerade mal ausgetestet. Klapp hervorragend. Wahnsinn, vielen Dank :-)!


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