Dieses Forum nutzt Cookies
Dieses Forum verwendet Cookies, um deine Login-Informationen zu speichern, wenn du registriert bist, und deinen letzten Besuch, wenn du es nicht bist. Cookies sind kleine Textdokumente, die auf deinem Computer gespeichert werden. Die von diesem Forum gesetzten Cookies werden nur auf dieser Website verwendet und stellen kein Sicherheitsrisiko dar. Cookies aus diesem Forum speichern auch die spezifischen Themen, die du gelesen hast und wann du zum letzten Mal gelesen hast. Bitte bestätige, ob du diese Cookies akzeptierst oder ablehnst.

Ein Cookie wird in deinem Browser unabhängig von der Wahl gespeichert, um zu verhindern, dass dir diese Frage erneut gestellt wird. Du kannst deine Cookie-Einstellungen jederzeit über den Link in der Fußzeile ändern.

VBA: Mit jedem Klick auf Button eine Zahl hinzufügen
#1
Hallo,

ich habe Buttons von 0-9 in Excel erstellt und möchte jetzt durch klicken auf die Buttons eine Zahl eingeben, die dann in einer Zelle nach und nach erscheint. Wie bei der Eingabe in einen Taschenrechner. Ich habe es bisher nur soweit hinbekommen, dass wenn ich auf einen Button klicke die vorherige Zahl wieder verschwindet und durch die neue ersetzt wird.

Es ist nur eine Aufgabe, die ich mir selbst überlegt habe um VBA zu lernen.

Gruß
Antworten Top
#2
Hallo Z...,

anstatt
Range("A1") =  9

nimm
Range("A1") = Range("A1") & 9


ps. Wenn die Zelle als Zahl formatiert ist, geht es nur bis zur 16. Stelle.
helmut

Für mich ist die Möglichkeit in Excel an Zellen und Bereichen Namen zu vergeben die wichtigste Funktionalität.
Sie macht Formeln und den VBA-code verständlicher. Für Makros gilt die Regel: "Nur über benannte Bereiche auf den Inhalt der Zellen zugreifen."
Und wofür sind Regeln da? Um nachzudenken bevor man sie bricht.





Antworten Top
#3
Hallo,

z.B.:
Sub Ziffer_1_Anfuegen()
With Range("B2")
.Value = .Value & 1
End With
End Sub
Gruß Uwe
Antworten Top
#4
Danke!
Antworten Top
#5
(28.03.2018, 15:05)7soory schrieb: Es ist nur eine Aufgabe, die ich mir selbst überlegt habe um VBA zu lernen.

Moin!
Dann solltest Du wissen, dass die Verkettung eine Textzahl ergibt und bei Überschreitung der Rechengenauigkeit von Excel (siehe Ego) falsche Ergebnisse bewirkt!
Merke:
In VBA sollten alle Variablen einem bestimmten Datentyp zugewiesen werden.
Bei Zahlen also Double, Long oder auch Currency …
Den Text wandelst Du mittels CDbl(), CLng() oder CCur() in die Zahl um.

By the way:
Ich habe mal einen sehr guten Rechner mittels VBA programmiert und verrate hier den gesamten Code:
Code:
Sub Rechner()
Shell "calc"
End Sub

Gruß Ralf
Gib einem Mann einen Fisch und du ernährst ihn für einen Tag. 
Lehre einen Mann zu fischen und du ernährst ihn für sein Leben. (Konfuzius)
[-] Folgende(r) 1 Nutzer sagt Danke an RPP63 für diesen Beitrag:
  • 7soory
Antworten Top
#6
Hallöchen,

in der Regel passt bestimmt auch

.Value = .Value * 10 + 1 'bzw. die Zahl vom Button
.      \\\|///      Hoffe, geholfen zu haben.
       ( ô ô )      Grüße, André aus G in T  
  ooO-(_)-Ooo    (Excel 97-2019+365)
Antworten Top


Gehe zu:


Benutzer, die gerade dieses Thema anschauen: 1 Gast/Gäste