Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de
  AutoCAD VBA
  Mtext bearbeiten

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte
  
PNY: der unverzichtbare Partner für umfassende KI-Lösungen von Workstations bis zu Edge Computing und KI-Cluster-Bereitstellung, eine Pressemitteilung
Autor Thema:  Mtext bearbeiten (1571 mal gelesen)
It is me
Mitglied


Sehen Sie sich das Profil von It is me an!   Senden Sie eine Private Message an It is me  Schreiben Sie einen Gästebucheintrag für It is me

Beiträge: 5
Registriert: 23.09.2003

erstellt am: 23. Sep. 2003 14:27    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo Forum
Ich möchte in einem Mtxt nach "xy" suchen und durch "ätsch" mit dem Stil wingdings ersetzen.
Bisher hatte ich leider keinen Erfolg.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

RoSiNiNo
Mitglied
Konstrukteur


Sehen Sie sich das Profil von RoSiNiNo an!   Senden Sie eine Private Message an RoSiNiNo  Schreiben Sie einen Gästebucheintrag für RoSiNiNo

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 24. Sep. 2003 07:02    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für It is me 10 Unities + Antwort hilfreich

Hallo It is Me,
ich begrüße dich in diesem tollen Forum.
Zuerst ließ einmal das hier Supportangaben zu PC und Software - Fragen schneller und besser beantworten.
Hier der Code den du brauchst.
Code:
Public Sub MTextTextChange()
    Dim ObjText As AcadMText
    Dim Pt As Variant
    Dim ObjTextOverride As String
    Const Textsearch  As String = "xy"
    Const Textoverride As String = "ätsch"
    Dim ObjTextOverrideSplit As Variant
   
   
    On Error GoTo Err_Control
    GetEntityEx ObjText, Pt, vbCr & "MText wählen: "
    ObjTextOverride = ObjText.textString
   
    If InStr(1, ObjTextOverride, Textsearch) > 0 Then
        ObjTextOverrideSplit = Split(ObjTextOverride, Textsearch)
       
        Dim i As Long
        Dim Anzahl As Long
       
        Anzahl = UBound(ObjTextOverrideSplit)
       
        ObjTextOverride = ObjTextOverrideSplit(0) & Textoverride
       
        For i = 1 To Anzahl
           
            If Anzahl = 1 Then
                ObjTextOverride = ObjTextOverride & ObjTextOverrideSplit(i)
            Else
                If i < Anzahl Then
                    ObjTextOverride = ObjTextOverride & ObjTextOverrideSplit(i) & Textoverride
                Else
                    ObjTextOverride = ObjTextOverride & ObjTextOverrideSplit(i)
                End If
            End If
           
        Next i
    End If
   
    ObjText.textString = ObjTextOverride
    ObjText.Update
    Set ObjText = Nothing
   
Exit_Here:
    Exit Sub
Err_Control:
    Err.Clear
    Resume Exit_Here
   
End Sub

Public Sub GetEntityEx(ent As Object, pickedPoint, Optional Prompt)

    On Error Resume Next
StartLoop:
    ActiveDocument.Utility.GetEntity ent, pickedPoint, Prompt
    If Err Then
        If ActiveDocument.GetVariable("errno") = 7 Then
            Err.Clear
            GoTo StartLoop
        Else
            Err.Raise vbObjectError + 5, , "User cancelled operation"
        End If
    End If

End Sub



------------------
Roland

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

RoSiNiNo
Mitglied
Konstrukteur


Sehen Sie sich das Profil von RoSiNiNo an!   Senden Sie eine Private Message an RoSiNiNo  Schreiben Sie einen Gästebucheintrag für RoSiNiNo

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 24. Sep. 2003 11:39    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für It is me 10 Unities + Antwort hilfreich

Entschuldig, der Code oben ist zwar nicht falsch, aber doch ein totaler Blödsinn da es die Funktion Replace ja schon gibt.
Daher nochmals das Beispiel, nun aber richtig.
Code:
Public Sub MTextTextChange1()
    Dim ObjText As AcadMText
    Dim Pt As Variant
    Dim ObjTextOverride As String
    Const Textsearch  As String = "xy"
    Const Textoverride As String = "ätsch"
   
   
    On Error GoTo Err_Control
    GetEntityEx ObjText, Pt, vbCr & "MText wählen: "
    ObjTextOverride = ObjText.textString
   
    ObjTextOverride = Replace(ObjTextOverride, Textsearch, Textoverride)
   
    ObjText.textString = ObjTextOverride
    ObjText.Update
    Set ObjText = Nothing
   
Exit_Here:
    Exit Sub
Err_Control:
    Err.Clear
    Resume Exit_Here
   
End Sub

------------------
Roland

[Diese Nachricht wurde von RoSiNiNo am 24. September 2003 editiert.]

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

It is me
Mitglied


Sehen Sie sich das Profil von It is me an!   Senden Sie eine Private Message an It is me  Schreiben Sie einen Gästebucheintrag für It is me

Beiträge: 5
Registriert: 23.09.2003

erstellt am: 25. Sep. 2003 08:53    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Danke für die Hilfe aber den schwierigsten Teil hast du leider übersehen.
Der neu eingefügte Text soll in einem anderen Schriftstil (Wingdings)eingefügt werden.
Hier bin ich bisher kläglich gescheitert.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

RoSiNiNo
Mitglied
Konstrukteur


Sehen Sie sich das Profil von RoSiNiNo an!   Senden Sie eine Private Message an RoSiNiNo  Schreiben Sie einen Gästebucheintrag für RoSiNiNo

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 25. Sep. 2003 09:07    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für It is me 10 Unities + Antwort hilfreich

Dann probier es einmal damit:
Code:
Public Sub MTextTextChange1()
    Dim ObjText As AcadMText
    Dim Pt As Variant
    Dim ObjTextOverride As String
    Const Textsearch  As String = "xy"
    Const Textoverride As String = "{\fWingdings;ätsch}"
   
   
    On Error GoTo Err_Control
    GetEntityEx ObjText, Pt, vbCr & "MText wählen: "
    ObjTextOverride = ObjText.textString
   
    ObjTextOverride = Replace(ObjTextOverride, Textsearch, Textoverride)
   
    ObjText.textString = ObjTextOverride
    ObjText.Update
    Set ObjText = Nothing
   
Exit_Here:
    Exit Sub
Err_Control:
    Err.Clear
    Resume Exit_Here
   
End Sub

------------------
Roland

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

It is me
Mitglied


Sehen Sie sich das Profil von It is me an!   Senden Sie eine Private Message an It is me  Schreiben Sie einen Gästebucheintrag für It is me

Beiträge: 5
Registriert: 23.09.2003

erstellt am: 25. Sep. 2003 10:34    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo

noch ne Frage
Warum funktioniert das unter acad aber nicht mit Autocad Mechanical
Er kennt den Befehl "Replace" nicht.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

RoSiNiNo
Mitglied
Konstrukteur


Sehen Sie sich das Profil von RoSiNiNo an!   Senden Sie eine Private Message an RoSiNiNo  Schreiben Sie einen Gästebucheintrag für RoSiNiNo

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 25. Sep. 2003 10:43    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für It is me 10 Unities + Antwort hilfreich

Kommt auf die Version an, geht glaube ich erst ab 2002.
Sost verwende einfach erstes Beispiel.

------------------
Roland

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

It is me
Mitglied


Sehen Sie sich das Profil von It is me an!   Senden Sie eine Private Message an It is me  Schreiben Sie einen Gästebucheintrag für It is me

Beiträge: 5
Registriert: 23.09.2003

erstellt am: 25. Sep. 2003 10:45    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hab ich versucht
Hier kennt VBA den befehl "Split" nicht

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

RoSiNiNo
Mitglied
Konstrukteur


Sehen Sie sich das Profil von RoSiNiNo an!   Senden Sie eine Private Message an RoSiNiNo  Schreiben Sie einen Gästebucheintrag für RoSiNiNo

Beiträge: 1126
Registriert: 09.10.2002

Acad 2011-deutsch, Express Tools
3ds Max 2010
Win 7-Professional
HP Workstation Z400, 6GB
GeForce GTX 470

erstellt am: 25. Sep. 2003 10:48    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für It is me 10 Unities + Antwort hilfreich

Versuch es damit:
Code:
Public Function Split(Str As String, Delim As String) As Variant

    Dim tokens() As String, pos As Long, i As Integer

    pos = InStr(1, Str, Delim, vbTextCompare)
    i = 0

    Do While pos > 0
      ReDim Preserve tokens(0 To i)
      tokens(i) = Mid$(Str, 1, pos - 1)
      If tokens(i) = Delim Then tokens(i) = ""
      Str = Mid$(Str, pos + Len(Delim))
      i = i + 1
      pos = InStr(1, Str, Delim, vbTextCompare)
    Loop

    If Len(Str) > 0 Then
      ReDim Preserve tokens(0 To i)
      tokens(i) = Str
    End If

    Split = tokens

End Function


------------------
Roland

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

It is me
Mitglied


Sehen Sie sich das Profil von It is me an!   Senden Sie eine Private Message an It is me  Schreiben Sie einen Gästebucheintrag für It is me

Beiträge: 5
Registriert: 23.09.2003

erstellt am: 25. Sep. 2003 11:30    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Danke Danke Danke
Vielen Dank

Nun läuft alles ohne Probleme

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2025 CAD.de | Impressum | Datenschutz