vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Top-Preis! AP-Access-Tools-CD Volume 1  
 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
Betrag in Worten umsetzen 
Autor: Crysis
Datum: 15.08.10 09:51

Hallo, habe folgenden Code aus dem Forum geholt. Es dreht sich um das Umwandeln von Zahlen in ausgeschriebenen Sätzen.
Leider weiß ich nicht wie ich aus einer TextBox die Werte in die Funktion und am Ende sie in eine TextBox anzeigen lassen kann.
' Rufen Sie in Ihrem Programm die nachfolgende Routine auf,
' um eine Ganzzahl in Worten umzuwandeln. Sie übergeben der
' Funktion einfach die Zahl und erhalten dann den Text als
' String zurück
 
Public Function BetragInWorten(ByVal Betrag As Double) _
  As String
 
  Dim sBetrag As String
  Dim I As Integer
  Dim Gruppe As String
  ReDim tmp1(3) As String
  ReDim tmp2(3) As String
  ReDim Grp(4) As String
 
  If Betrag = 0 Then
    BetragInWorten = "null"
  Else
    tmp1(1) = "einemilliarde": tmp2(1) = "milliarden"
    tmp1(2) = "einemillion": tmp2(2) = "millionen"
    tmp1(3) = "eintausend": tmp2(3) = "tausend"
 
    sBetrag = LTrim$(Str$(Betrag))
    sBetrag = String$(12 - Len(sBetrag), "0") + sBetrag
    For I = 1 To 4
      Gruppe = Mid$(sBetrag, (I - 1) * 3 + 1, 3)
      If Gruppe <> "000" Then
        If I <> 4 Then
          If Gruppe = "001" Then
            Grp(I) = tmp1(I)
          Else
            Grp(I) = GetGruppe(Gruppe) + tmp2(I)
          End If
        Else
          Grp(I) = GetGruppe(Gruppe)
        End If
      End If
    Next I
    BetragInWorten = Grp(1) + Grp(2) + Grp(3) + Grp(4)
  End If
End Function
 
' Die nachfolgende Funktion wird von der Hauptfunktion
' aufgerufen
Private Function GetGruppe(ByVal Gruppe As String) As String
 
  ' Dreiergruppen in Worten zusammenfassen
 
  Dim Hunderter As String
  Dim Zehner As String
  Dim Einer As String
 
  ' Hunderterstellen
  If Val(Mid$(Gruppe, 1, 1)) > 0 Then
    If Mid$(Gruppe, 1, 1) = "1" Then
      Hunderter = "einhundert"
    Else
      Hunderter = Choose(Val(Mid$(Gruppe, 1, 1)) + 1, "null", _
        "eins", "zwei", "drei", "vier", "fünf", "sechs", _
        "sieben", "acht", "neun") + "hundert"
    End If
  End If
 
  ' Zehnerstellen
  If Val(Right$(Gruppe, 2)) >= 10 And _
    Val(Right$(Gruppe, 2)) < 20 Then
    Einer = Choose(Val(Right$(Gruppe, 2)) - 9, "zehn", "elf", _
      "zwölf", "dreizehn", "vierzehn", "fünfzehn", "sechzehn", _
      "siebzehn", "achtzehn", "neunzehn")
  Else
    If Val(Mid$(Gruppe, 2, 1)) > 1 Then
      Zehner = Choose(Val(Mid$(Gruppe, 2, 1)) - 1, "zwanzig", _
        "dreißig", "vierzig", "fünfzig", "sechzig", "siebzig", _
        "achtzig", "neunzig")
    End If
    If Val(Mid$(Gruppe, 3, 1)) > 0 Then
      ' Einerstellen
      If Zehner = "" Then
        Einer = Choose(Val(Mid$(Gruppe, 3, 1)) + 1, "null", _
          "eins", "zwei", "drei", "vier", "fünf", "sechs", _
          "sieben", "acht", "neun")
      Else
        If Mid$(Gruppe, 3, 1) = "1" Then
          Einer = "einund"
        Else
          Einer = Choose(Val(Mid$(Gruppe, 3, 1)) + 1, "null", _
            "eins", "zwei", "drei", "vier", "fünf", "sechs", _
            "sieben", "acht", "neun") + "und"
        End If
      End If
    End If
  End If
 
 Text8.Text = GetGruppe = Hunderter + Einer + Zehner
End Function
Mfg. Crysis
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Betrag in Worten umsetzen1.563Crysis15.08.10 09:51
Re: Betrag in Worten umsetzen974mst54715.08.10 11:07
Re: Betrag in Worten umsetzen892Crysis15.08.10 12:06

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