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.

Nicht genügend Stapelspeicher (Fehler 28)
#1
Guten Morgen zusammen,

eigentlich ist die Datei sehr einfach. 
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Range("A1") = Application.WorksheetFunction.Sum(Range("A2:A30"))

End Sub


Ich versuche in dem Bereich A2:A30 die Eingaben zu summieren. Ich wollte in A1 einen Code ohne die Anzeige der Formel.
Die Berechnung soll automatisch geschehen.

Nach jeder Eingabe in A2:A30 erscheint die Fehlermeldung "Nicht genügend Stapelspeicher". Ich habe mehrere Male den Rechner neu gestartet, aber half nicht.

Die Datei füge ich bei.
Warum funktioniert der Code in dem Beispiel nicht? 

Bedanke mich im Voraus für die Hilfe.


Angehängte Dateien
.xlsb   Summe.xlsb (Größe: 17,03 KB / Downloads: 2)
Antworten Top
#2
Moin!
Zunächst mal die berechtigte Frage: Warum schreibst Du nicht einfach =SUMME(A2:A30) in A1?
Dürfte Excel rechentechnisch nicht ans Limit bringen.  19

Zum Thema:
Das Ereignismakro landet in einer Endlosschleife!

Lösung 1:
Kapsel das Makro mit Application.EnableEvents = True / False

Lösung 2 (viel besser):
Löse das Makro erst dann aus, wenn sich im Bereich A2:A30 etwas ändert!

Code:
Private Sub Worksheet_Change(ByVal Target As Range)
If Not Intersect(Range("A2:A30"), Target) Is Nothing Then
  Range("A1") = WorksheetFunction.Sum(Range("A2:A30"))
End If
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:
  • Tommiks
Antworten Top
#3
Besten Dank... 18
Antworten Top


Gehe zu:


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