bn2023
Goto Top

VBA-Makro in Word funktioniert nicht

Guten Tag,

ich habe ein VBA-Makro in Word geschrieben (Office 365).
Darin will ich einfach nur 1,5 Zeilen in einem Text markieren und dann löschen lassen.
Ich habe schon viele Makros erstellt, aber dieses funktioniert nicht.

So habe ich es gemacht:
Ich habe in Word also "Makro aufzeichnen" gewählt, dann diese 1,5 Zeilen Text markiert und dann per Entf.-Taste gelöscht. Dann die Makro-Aufzeichnung beendet.

Ergebnis ist das hier:
Sub txt()
'  
' txt Makro  
'  
'  
    Selection.Delete Unit:=wdCharacter, Count:=1
End Sub

Kann mir jemand von Euch weiterhelfen?

Grüße,
BN

Content-ID: 71366169766

Url: https://administrator.de/contentid/71366169766

Ausgedruckt am: 18.11.2024 um 23:11 Uhr

godlie
godlie 06.10.2023 um 12:57:46 Uhr
Goto Top
Hallo,

wo ist jetzt dein Problem? In der Anwendung des Markos oder in der Ausführung?

grüße
BN2023
BN2023 06.10.2023 um 13:01:33 Uhr
Goto Top
Danke für die schnelle Antwort.

Nun... wenn ich dieses Makro nun ausführe, passiert einfach nichts!
Der Text steht weiterhin dort.

Grüße,
BN
godlie
godlie 06.10.2023 um 13:05:10 Uhr
Goto Top
Der Text muss ausgewählt werden, damit etwas ersetzt wird, dass Makro wird nur auf den ausgewählten Text angewendet
kpunkt
kpunkt 06.10.2023 um 13:11:04 Uhr
Goto Top
Da steht "Selection.Delete"
Was wurde denn ausgewählt?
BN2023
BN2023 06.10.2023 um 13:18:17 Uhr
Goto Top
Hmmm... vielleicht mache ich ja auch einen Denkfehler.
Ich hatte bei Erstellung des Makros ja den Text markiert und dann gelöscht.
Nun dachte ich, dass sich das Makro quasi diesen Text auch merkt.

Ansonsten könnte ich es ja mit "Selection.Find.Replacement.ClearFormatting" machen.
Aber der Inhalt dieser 1,5 Zeilen Text ändert sich immer wieder in jedem neuen Dokument. Er steht halt immer nur an der gleichen Stelle und soll halt gelöscht werden.

Wie kann ich das denn ansonsten umsetzen... bzw. geht das überhaupt?

Grüße,
BN
BN2023
BN2023 06.10.2023 um 13:22:34 Uhr
Goto Top
Ich gebe mal ein Beispiel:

Im Worddokument steht...


Die Überweisung erfolgt ab Mitte November auf das Konto:
Max Mustermann:
- Sonderzuwendung, 60,00 € auf DE123123456456789 bei der SPARKASSE FULDA


Und gelöscht werden soll alles nach dem Doppelpunkt nach "Konto" bis einschließlich des Wortes "auf" for der IBAN.

Vielleicht wird es jetzt besser verständlich face-wink

Grüße,
BN
kpunkt
kpunkt 06.10.2023 um 13:26:08 Uhr
Goto Top
Was genau verstehst du übrigens unter "1,5 Zeilen Text"?
Tipp Makrorekorder:
Selection.Find.Execute FindText:="Text", ReplaceWith:="", Forward:=True, Wrap:=wdFindContinue, Replace:=wdReplaceAll  
7907292512
Lösung 7907292512 06.10.2023 aktualisiert um 15:27:53 Uhr
Goto Top
Mit Replace so
ActiveDocument.Content.Find.Execute FindText:=":*auf", Forward:=True, ReplaceWith:="", Replace:=wdReplaceOne, MatchWildcards:=True  
Oder zu Fuß so
Dim rngSearch As Range, intStart As Integer, intEnd As Integer
Set rngSearch = ActiveDocument.Content
rngSearch.Find.Execute FindText:="Konto:", Forward:=True  
If rngSearch.Find.Found Then
    intStart = rngSearch.End - 1
    Set rngSearch = ActiveDocument.Content
    rngSearch.Find.Execute FindText:="auf DE"  
    If rngSearch.Find.Found Then
        intEnd = rngSearch.Start + 4
        ActiveDocument.Range(intStart, intEnd).Delete
    End If
End If
🖖
Gruß sid.
BN2023
BN2023 09.10.2023 aktualisiert um 10:26:30 Uhr
Goto Top
Danke Dir @7907292512 für den Code.

Er funktioniert zu 98% auch...
Nur wird bei der Umsetzung

1) der Doppelpunkt hinter "Konto" mit entfernt
2) vor dem DE von der IBAN wird eine zusätzliche Leerstelle eingefügt.

Sieht jetzt so aus:
Die Überweisung erfolgt ab Mitte November auf das Konto
 DE123123456456789 bei der SPARKASSE FULDA

Hast Du noch einen Tipp, wie ich das anpassen kann?

Danke und Grüße,
BN
7907292512
7907292512 09.10.2023 aktualisiert um 10:45:46 Uhr
Goto Top
Ja code einmal lesen und verstehen und Start und Endindex anpassen 😁
intStart = rngSearch.End - 1
wird zu
intStart = rngSearch.End

Nr. 2 ist deine Hausaufgabe aber genauso schnell erledigt😁. Tipp: Variable "intEnd"
BN2023
BN2023 09.10.2023 aktualisiert um 11:31:25 Uhr
Goto Top
Hallo @7907292512 und danke für die Tipps.

Ich habe es jetzt bei der Variable "intEnd" versucht mit:
+ 5
+ 3
+ 2
+ 4 - 1

...aber Alles ist noch keine Lösung für die eine Leerstelle vor "DE........."

Bräuchte vielleicht noch nen kleinen Tipp face-wink

Grüße,
BN
7907292512
7907292512 09.10.2023 aktualisiert um 11:54:46 Uhr
Goto Top
Ausprobieren ist nicht Sinn der Übung, sondern das Verständnis des Codes ... sobald du ihn verstehst weist du auch genau was zu tun ist face-wink. Also nicht dumm in der Gegend rum probieren sondern die grauen Zellen in Wallung bringen.

Mein Testergebnis mitdem was du uns hier "leider ohne Codetags" geliefert hast:

screenshot

mit
Sub RemoveText()
    Dim rngSearch As Range, intStart As Integer, intEnd As Integer
    Set rngSearch = ActiveDocument.Content
    rngSearch.Find.Execute FindText:="Konto:", Forward:=True  
    If rngSearch.Find.Found Then
        intStart = rngSearch.End
        Set rngSearch = ActiveDocument.Content
        rngSearch.Find.Execute FindText:="auf DE"  
        If rngSearch.Find.Found Then
            intEnd = rngSearch.Start + 3
            ActiveDocument.Range(intStart, intEnd).Delete
        End If
    End If
End Sub

Works as designed!

I'm out. 🖖
BN2023
BN2023 09.10.2023 um 11:46:23 Uhr
Goto Top
Danke Dir... aber ich muss zu meiner Entschuldigung sagen, dass ich mich mit Code so überhaupt nicht auskenne. Daher wußte ich auch nicht wirklich, was ich sonst noch probieren sollte.

Das mit + 3 hatte ich ja auch schon versucht...
Es soll halt so sein, dass hinter "Konto:" in die nächste Zeile umgebrochen wird.
Diese soll dann direkt vorne mit "DE" beginnen.

Ich teste jetzt nochmal mit Deinem kompletten Code, den Du eben gepostet hast.

Danke bis dahin.

Grüße,
BN
7907292512
7907292512 09.10.2023 aktualisiert um 11:51:41 Uhr
Goto Top
Zitat von @BN2023:
Es soll halt so sein, dass hinter "Konto:" in die nächste Zeile umgebrochen wird.
Diese soll dann direkt vorne mit "DE" beginnen.
Das stand bisher nirgendwo...
Ich zitiere:
Und gelöscht werden soll alles nach dem Doppelpunkt nach "Konto" bis einschließlich des Wortes "auf" for der IBAN.
Lässt sich aber leicht einfügen.
https://learn.microsoft.com/de-de/office/vba/api/word.range.insertafter
BN2023
BN2023 09.10.2023 um 11:50:43 Uhr
Goto Top
UPDATE:
Das Leerzeichen ist leider noch immer vor dem "DE" in der neuen Zeile.
Umgebrochen wird die Zeile jedoch!!

Grüße,
BN
7907292512
7907292512 09.10.2023 um 11:52:51 Uhr
Goto Top
Tja es gilt das was ich oben schon geschrieben habe wir haben hier nur das was du uns lieferst

Mein Testergebnis mitdem was du uns hier "leider ohne Codetags" geliefert hast:
7907292512
Lösung 7907292512 09.10.2023 aktualisiert um 11:56:16 Uhr
Goto Top
Sub RemoveText()
    Dim rngSearch As Range, intStart As Integer, intEnd As Integer
    Set rngSearch = ActiveDocument.Content
    rngSearch.Find.Execute FindText:="Konto:", Forward:=True  
    If rngSearch.Find.Found Then
        intStart = rngSearch.End + 1
        Set rngSearch = ActiveDocument.Content
        rngSearch.Find.Execute FindText:="auf DE"  
        If rngSearch.Find.Found Then
            intEnd = rngSearch.Start + 3
            ActiveDocument.Range(intStart, intEnd).Delete
        End If
    End If
End Sub

Vorher:

screenshot

Nachher:

screenshot
BN2023
BN2023 09.10.2023 aktualisiert um 11:57:17 Uhr
Goto Top
...ok, danke, werde ich gleich mal testen.

Grüße,
BN
7907292512
7907292512 09.10.2023 aktualisiert um 11:57:51 Uhr
Goto Top
s. Mein Ergebnis im letzten Kommentar!

Im Moment ist das der vollständige Code:
Du verstehst nicht, ich meine nicht den Code sondern den Original Text in Codetags wegen Sonderzeichen etc.!
BN2023
BN2023 09.10.2023 aktualisiert um 12:00:52 Uhr
Goto Top
yessssssssss, das hat funktioniert face-wink

Danke Dir.
Es lag also nur an dem + 1 hinter dem "rngSearch.End". Also eine Leerstelle, die am Anfang der neuen Zeile gelöscht werden soll? Verstehe ich das so richtig?

Grüße,
BN


"Original Text in Codetags" hätte ich jetzt auch nicht wirklich gewußt, was Du damit meinst. Aber funktioniert ja jetzt!! face-smile
7907292512
7907292512 09.10.2023 aktualisiert um 12:03:01 Uhr
Goto Top
Also eine Leerstelle, die am Anfang der neuen Zeile gelöscht werden soll? Verstehe ich das so richtig?
Nein, Zeilenumbrüche zählen auch als Zeichen., somit wird der Zeilenumbruch nicht gelöscht und bleibt erhalten.
BN2023
BN2023 09.10.2023 um 12:01:19 Uhr
Goto Top
ah ok, das verstehe ich.

Grüße,
BN
7907292512
7907292512 09.10.2023 aktualisiert um 12:08:38 Uhr
Goto Top
"Original Text in Codetags" hätte ich jetzt auch nicht wirklich gewußt, was Du damit meinst.

Damit meinte ich den Teil hier, da beim pasten als normaler Forums-Text eventuelle Sonderzeichen (Tabs, etc.)verloren gehen, wenn man ihn dagegen in Code-Tags einbettet bleiben diese erhalten. Das ist essentiell wenn man auf sämtliche Zeichen im Original als Programmierer angewiesen ist.
Die Überweisung erfolgt ab Mitte November auf das Konto:
Max Mustermann:
- Sonderzuwendung, 60,00 € auf DE123123456456789 bei der SPARKASSE FULDA
BN2023
BN2023 09.10.2023 um 12:08:34 Uhr
Goto Top
OK und danke für den weiteren Hinweis.
Werde ich in Zukunft bei ähnlichen Fragen so machen!

Danke für die Hilfe und Grüße,
BN