vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
vb@rchiv Offline-Reader - exklusiv auf der vb@rchiv CD Vol.4  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

Visual-Basic Einsteiger
Re: Einen bestimmten Text durch eine leere Zeichenfolge ersetzen 
Autor: gaminator
Datum: 13.05.10 23:14

Hallo Zardoz! Schönen Dank! Ich hab es ausprobiert und jetzt funktioniert die Textersetzung, jedoch nur einmal. (also nur von einem einzigen Wort werden die Klammern ersetzt)
Ich habe leider keine Ahnung, wie man die Funktion durchlaufen lassen kann, bis keine Klammern mehr gefunden werden. Hast Du da eine Idee?


Mein bisheriger Code:


Option Explicit
Dim mText As String
Dim mTextlaenge As String
Dim i As Integer
Dim i2 As Integer
 
Dim mTextbuffer As String
 
Dim mPosition1 As Integer
Dim mPosition2 As Integer
 
 
Function FunktionUebersetzen(mText As String)
 
'[text] Nur Klammern entfernen
'[+text] Klammer un +-Zeichen entfernen
'[-text] Klammer mitsamt Inhalt entfernen
 
mTextlaenge = Len(mText)
 
 
For i = 1 To mTextlaenge
 
    If Mid(mText, i, 2) = "[-" Then
 
     mPosition1 = i
 
     mTextbuffer = Mid(mText, 1, mPosition1 - 1)
 
     For i2 = i To mTextlaenge
 
     If Mid(mText, i2, 1) = "]" Then
 
     mPosition2 = i2
 
     'Inhalt der Klammer entfernen
     mTextbuffer = mTextbuffer & Mid(mText, mPosition1 + (mPosition2 - _
       mPosition1) + 1, mTextlaenge - mPosition2 + 1)
 
     End If
 
     Next i2
 
    End If
 
Next i
 
For i = 1 To mTextlaenge
 
    If Mid(mText, i, 2) = "[+" Then
 
     mPosition1 = i
 
     mTextbuffer = Mid(mText, 1, mPosition1 - 1)
 
     For i2 = i To mTextlaenge
 
     If Mid(mText, i2, 1) = "]" Then
 
     mPosition2 = i2
 
     'Erstmal das "[+" Zeichen entfernen
     mTextbuffer = mTextbuffer & Mid(mText, mPosition1 + 2, mPosition2 - _
       mPosition1 - 2)
 
     'Das "]" Zeichen entfernen
     mTextbuffer = mTextbuffer & Mid(mText, mPosition2 + 1, mTextlaenge - _
       mPosition2)
     End If
 
     Next i2
 
    End If
 
Next i
 
For i = 1 To mTextlaenge
 
    If Mid(mText, i, 1) = "[" Then
 
     mPosition1 = i
 
     mTextbuffer = Mid(mText, 1, mPosition1 - 1)
 
     For i2 = i To mTextlaenge
 
     If Mid(mText, i2, 1) = "]" Then
 
     mPosition2 = i2
 
     'Erstmal das "[" Zeichen entfernen
     mTextbuffer = mTextbuffer & Mid(mText, mPosition1 + 1, mPosition2 - _
       mPosition1 - 1)
 
     'Das "]" Zeichen entfernen
     mTextbuffer = mTextbuffer & Mid(mText, mPosition2 + 1, mTextlaenge - _
       mPosition2)
     End If
 
     Next i2
 
    End If
 
Next i
 
FunktionUebersetzen = mTextbuffer
 
End Function
 
 
 
 
 
Private Sub btnUebersetzen_Click()
 
txtZiel.Text = FunktionUebersetzen(txtQuelle.Text)
 
End Sub


Beitrag wurde zuletzt am 13.05.10 um 23:15:46 editiert.
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Einen bestimmten Text durch eine leere Zeichenfolge ersetzen1.620gaminator13.05.10 21:40
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.113gaminator13.05.10 22:02
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.161Zardoz13.05.10 22:49
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.094gaminator13.05.10 23:14
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.205JAG14.05.10 00:02
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.197gaminator14.05.10 00:31
Re: Einen bestimmten Text durch eine leere Zeichenfolge erse...1.116JAG14.05.10 12:18

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel