Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst Excel: Makro aufgerufen über Worksheet Calculate () funktioniert nicht mehr wie es soll

Mitglied: BerndVorwerk

BerndVorwerk (Level 1) - Jetzt verbinden

08.08.2014, aktualisiert 13.08.2014, 3118 Aufrufe, 4 Kommentare

Hallo an alle,
ich muss mich schon wieder an euch wenden.

wenn ich über den Befehl "Worksheet_Change(ByVal Target As Range)" angebe, dass das Makro "copy1" ausgeführt werden soll, funktioniert alles wie es soll:

Private Sub Worksheet_Change(ByVal Target As Range)
  • If Target.Address = "$B$25" Then
    • copy1
  • End If
end sub


Sub copy1()
Dim c As Integer, r As Integer, rngSearch As Range
If Sheets("Bewertungsübersicht").Range("B25") = "X" Then
  • Set rngSearch = Sheets("Versuchsauftrag").Range("A85:C86")
    • For c = 1 To rngSearch.Columns.Count
      • For r = 1 To rngSearch.Rows.Count
        • If rngSearch.Cells(r, c).Value = "" Then
          • rngSearch.Cells(r, c).Value = Sheets("Bewertungsübersicht").Range("A25")
          • Exit Sub
        • End If
      • Next
    • Next
    End If

    Der Bereich A85 bis C68 wird nach einer freien Zelle durchsucht. In die wird dann ein Text eingefügt, der im Registerblatt "Bewertungsübersicht" in Zelle A25 steht. Sobald er einmal eingefügt wurde, wird das Makro durch "Exit Sub" abgebrochen, so dass nicht in die weiteren leeren zellen eingefügt wird. Soweit alles gut!
    Jetzt wird die Zelle B25 aber meistens mittels einer Formel geändert (bzw. in seltenen fällen weiterhin manuell) weshalb "Worksheet_Change" nicht mehr funktioniert.
    Ändere ich jetzt auf

    Private Sub Worksheet_Calculate()
    • call copy1
    end sub

    wird copy1 so wie es scheint nicht mehr durch "exit sub" unterbrochen, sondern der Text wird in alle freien Zellen des Bereiches eingefügt.
    Ich hoffe ich konnte mich verständlich ausdrücken und ihr könnt mir helfen.
    Vielen Dank einmal mehr!!
    Freundlicher Grüße,
    Bernd

Mitglied: colinardo
08.08.2014, aktualisiert um 15:45 Uhr
Moin Bernd,
dafür habe ich nur eine einzige Erklärung: Du hast vergessen das vorher verwendete Worksheet_Change Event zu löschen, denn dann kommt es zu diesem Verhalten

Grüße Uwe
Bitte warten ..
Mitglied: BerndVorwerk
08.08.2014 um 15:55 Uhr
Hi Uwe,
erst mal danke für die wieder einmal sehr schnelle Antwort!
In dem entsprechenden Excel Objekt (dem Tabellenblatt) steht lediglich folgendes:

Private Sub CommandButton1_Click()
  • BewKrit_LR_kopieren
End Sub

Private Sub Worksheet_Calculate()
  • Call copy1
End Sub

Ich hoffe doch, dass der CommandButton da keine Probleme macht. Der hat eigentlich mit der ganzen Sache nichts zu tun, löst bloß ein völlig anderes Makro aus. Vom vorherigen Worksheet_Change ist nichts mehr vorhanden.

Oder was meisnt du mit Worksheet_Change Event?
Gruß,
Bernd
Bitte warten ..
Mitglied: colinardo
LÖSUNG 08.08.2014, aktualisiert 13.08.2014
Dann wird das Worksheet_Calculate Event bei dir durch irgendwas mehrfach hintereinander aufgerufen. Aber das ist eine sehr unzuverlässige Lösung, denn wenn du irgendwas im Sheet änderst wird diese Funktion immer aufgerufen auch wenn sich der Status der gewünschten Zelle nicht verändert hat. Das kannst du nur durch ein speichern des "vorherigen" Wertes von B25 in einer öffentlichen Variablen oder einer anderen Zelle verhindern, welche du dann mit dem aktuellen Wert von B25 vergleichst, und nur dann den Einfügevorgang startest.

Oder was meisnt du mit Worksheet_Change Event?
Ich meine einen Eventhandler im zweiten Arbeitsblatt - also in dem Blatt wo nach den leeren Zellen gesucht wird...Wenn dort nämlich der Worksheet_Change Eventhandler vorhanden wäre, welcher deine Funktion aufruft, würde er jedes mal die Funktion erneut aufrufen, wenn sich im 2.ten Blatt was ändert, und das tut es ja jedes mal wenn im ersten Blatt das Calculate-Event feuert und Blatt 2 verändert.
Bitte warten ..
Mitglied: BerndVorwerk
13.08.2014 um 09:15 Uhr
Hallo Uwe,
wieder einmal Danke. Ich lasse das Makro jetzt per Button ausführen. Das ist zwar nicht so "automatisch", aber man hat es besser unter Kontrolle!
Gruß,
Bernd
Bitte warten ..
Ähnliche Inhalte
Microsoft Office
Excel Worksheet in Word
gelöst Frage von 118080Microsoft Office

Abend Zusammen :-) Wir haben ein Word Dokument und darin ein Excel Sheet verknüpft. Ich habe die Verknüpfung in ...

VB for Applications
Excel Worksheet referenzieren
gelöst Frage von KraemerVB for Applications2 Kommentare

Moin zusammen, es ist schon eine ganze weile her, das ich wirklich was mit VBA gebastelt habe. Und irgendwie ...

Microsoft Office
Excel Makro
Frage von maloh1984Microsoft Office4 Kommentare

Hallo Habe ein Problem, ein Kunde der hat Excellisten mit Makro die lassen sich öffnen aber die Buttons reagieren ...

Microsoft Office
Excel-Makro
gelöst Frage von yuki13Microsoft Office7 Kommentare

Hallo Zusammen!! :-) Ich bin nicht so fit in Excel Makros und wollte mich hier erkundigen, ob mir jemand ...

Neue Wissensbeiträge
Erkennung und -Abwehr

Ups: Einfaches Nullzeichen hebelte den Anti-Malware-Schutzt in Windows 10 aus

Information von kgborn vor 1 StundeErkennung und -Abwehr

Windows 10 ist das sicherste Windows aller Zeiten, wie Microsoft betont. Insidern ist aber klar, das es da Lücken, ...

Windows 10

Windows 10 on ARM: von Microsoft entfernte Info - Klartext, was nicht geht

Information von kgborn vor 3 StundenWindows 10

Windows 10 on ARM ist ja eine neue Variante, die Microsoft im Verbund mit Geräteherstellern am Markt etablieren will. ...

Microsoft
TV-Tipp: Das Microsoft-Dilemma
Information von kgborn vor 3 StundenMicrosoft3 Kommentare

Aktuell gibt es in Behörden und in Firmen eine fatale Abhängigkeit von Microsoft und dessen Produkten. Planlos agieren die ...

Windows 10
Zero-Day-Lücke in Microsoft Edge
Information von kgborn vor 2 TagenWindows 10

In Microsofts Edge-Browser klafft wohl eine nicht geschlossene (0-Day) Sicherheitslücke im Just In Time Compiler (JIT Compiler) für Javascript. ...

Heiß diskutierte Inhalte
Windows 10
Windows 10 (1709) Tastur und Maus wieder einschalten?
Frage von LochkartenstanzerWindows 1025 Kommentare

Moin, Ich habe von einem Kunden einen Win10-Rechner bekommen, bei dem weder Tastatur noch Maus geht. Die Hardware funktioniert ...

Firewall
RB2011 Firewall Rule eine bestimmte Mac oder IP Adresse nicht zu blockieren
Frage von lightmanFirewall15 Kommentare

Hallo liebes Forum mit ihren Spezialisten. Ich habe meine Firewall so konfiguriert das kein Endgerät ohne meine Speziellen Erlaubnis ...

Humor (lol)
Was könnte man mit einem Server machen? Idee gesucht
Frage von 2SeitenHumor (lol)15 Kommentare

Hey Zusammen Ich habe einen alten HP G2 Rackserver zu Hause rumliegen. 28GB Ram, 1xAMD Prozi mit etwa 2GHz. ...

Server-Hardware
Server für Exchange 2016, Kaufberatung
Frage von MazenauerServer-Hardware10 Kommentare

Guten Tag werte Gemeinde, Vorab: Ich dachte es gab mal einen separaten Bereich für solche Anfragen, habe ich leider ...