Programme en vb

Résolu
simovitch -  
 dodita -
Bonjour,

svp , je cherche un programme en Vb qui permet de verifier si un mot est un palindrome :

le mot sera ecrit sur un textbox avec un botton Vérifeir qui donne la résultat sur un msgbox !
Configuration: Windows XP
Opera 9.26

17 réponses

  1. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Bonsoir,
    Un autre code :
    Private Sub Verifier_Click()
      Dim leMot As String
      leMot = TextBox1.Value
     
         If leMot = StrReverse(leMot) Then
         MsgBox "Il s'agit d'un palindrome"
         Else
         MsgBox "Il ne s'agit pas d'un palindrome"
         End If
    
    End Sub


    Bonne nuit
    6
  2. amigo
     
    bonsoir,

    Private Sub Verifier_Click()
    Dim i As Integer, texte As String

    'ecrire le mot à l'envers
    texte = ""
    For i = Len(Text1.Text) To 1 Step -1
    texte = texte & Mid(Text1.Text, i, 1)
    Next

    'comparer le mot à l'endroit et le mot à l'envers
    If Text1.Text = texte Then
    MsgBox Text1.Text & " est un palyndrome"
    Else
    MsgBox Text1.Text & " n'est pas un palyndrome"
    End If
    End Sub

    salut
    2
  3. simovitch
     
    Merci les amis !

    aquarelle, c'est quoi le role de la fonction StrReverse ??
    1
    1. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
       
      Bonjour,
      De rien, toujours ravie de pouvoir aider.
      StrReverse() est une fonction qui permet "d'écrire" un mot à l'envers (calcul l'inverse d'un mot). Par exemple, si tu écris StrReverse(radar) le résultat de la fonction sera radar, si tu écris StrReverse(chose), le résultat sera esohc.
      Bonne journée
      0
  4. simovitch
     
    Merci!

    j'ai une remarque , au lieu de déclarer lemot comme string , on peut le faire directement :
    Private Sub Verifier_Click()

    If text1.text = StrReverse(ltext1.text) Then
    MsgBox text1.text , & "Il s'agit d'un palindrome"
    Else
    MsgBox text1.text , & "Il ne s'agit pas d'un palindrome"
    End If

    End Sub
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Bonjour,
    Il faudrait que tu l'écrives ainsi :
    Private Sub Verifier_Click()
    
        If TextBox1.Text = StrReverse(TextBox1.Text) Then
        MsgBox TextBox1.Text & " est un palindrome"
        Else
        MsgBox TextBox1.Text & " n'est pas un palindrome"
        End If
        
    End Sub


    Car :
    ---> MsgBox text1.text , & "Il s'agit d'un palindrome" = motécrit il s'agit d'un palindrome
    ---> MsgBox text1.text , & "Il ne s'agit pas d'un palindrome" = motécrit il ne s'agit pas d'un palindrome,
    n'est pas vraiment du français correcte.

    A+
    0
  7. simovitch
     
    Ah , merci je comprend !!
    mais dis moi tu as ecrit textBox1.text , y a t'il un déférence entre textbox1.text et text1.text ??
    0
  8. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    En fait par défaut, lorsque tu crées une zone de texte dans une UserForm, la propriété Name de la zone de texte est TextBox1, si tu crées une deuxième la propriété Name sera TextBox2 etc.
    Mais tu peux changer le Name et mettre text1 au lieu de TextBox1.
    Voili voilou
    Bonne soirée
    0
  9. simovitch
     
    ah c'est juste la proprieté Name de la zone text :D ! j'ai cru que l'a une relation avec msgbox ! lool
    vraiment merci aquarelle , j'espere que tu m'aidera si je trouve des difficulté , j'ai un modéle de prog. Vb cette anné !
    merci pour votre aide :)
    0
  10. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Re,
    Il n'y a pas de souci, si tu as besoin d'aide, n'hésite pas à reposter un nouveau topic. Si je peux t'aider, je le ferai, sans aucun doute, mais t'inquiète pas, ici il y a beaucoup de personnes généreuses et passionnées qui pourront aussi t'aider.
    Tu devrais t'inscrire en tant que membre de CCM, c'est gratuit et cela facilite la recherche des messages auxquels on participe : http://www.commentcamarche.net/communaute/inscription.php3
    Bonne soirée et à+
    0
  11. simovitch Messages postés 5 Statut Membre
     
    Voila c'est fait !
    merci , bonne soiréé !
    0
  12. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Super !!!
    Alors bienvenue et à bientôt.
    0
  13. simovitch Messages postés 5 Statut Membre
     
    sinn , si je veut calculer le nombre d'espaces vides dans une phrase?,
    à l'image par exemple , j'ecris "c'est mon premier programe en Vb "
    clique sur verifier donne , 5 espaces !!!
    0
  14. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Bonsoir simovitch,
    Tout dabord,il te faut créer une fonction qui compte le nombre d'espaces dans une chaîne de caractère. Cette fonction est à placer dans un module :
    Function espaces(chaine As String) As Integer ' Compter le nombre d'espaces
    
    Const espace As String = " "
    Dim nbcar As Integer ' Nombre de caractères de la chaîne à traiter
    Dim i As Integer     ' Indice de boucle
    Dim nb As Integer     ' compteur d'espaces
    
    nbcar = Len(chaine)
    nb = 0
    
    For i = 1 To nbcar
    
         nb = nb + Abs(InStr(1, espace, Mid(chaine, i, 1)) <> 0)
    
    Next i
    
    espaces = nb ' Renvoie le résultat
    End Function


    Ensuite dans la UserForm au niveau du bouton :
    Private Sub CommandButton1_Click()
    MsgBox "La phrase contient " & espaces(TextBox1.Text) & " espaces"
    End Sub
    


    Bonne soirée et à+

    PS: la prochaine fois pour un nouveau sujet, ce serait bien que tu crées un nouveau topic (suje) comme tu l'as fait pour le palindrome ainsi d'autres personnes pourront s'y intéresser et t'apporter d'autres réponses. Ne connaissant pas très bien VB car j'utilise VBA sur excel, mes réponses vont vite être limitées.
    0
  15. simovitch Messages postés 5 Statut Membre
     
    ah ok !!!
    je le ferai la prochaine fois !!

    peut tu m'expliqué ce lign : nb = nb + Abs(InStr(1, espace, Mid(chaine, i, 1)) <> 0) !

    j'avait intention de creer une fonction pour cela mais le prof a dit sans le faire , c'est a dire d'utiliser juste les modéles foncions comme Len() et mid() et instr() , les fonctions usuals !
    0
  16. aquarelle Messages postés 7181 Date d'inscription   Statut Modérateur Dernière intervention   1 311
     
    Bonsoir simovitch,
    En gros, cela sert de compteur, au départ, nb= 0, ensuite il prend la première lettre de la chaine écrite, regarde si c'est un espace si oui, il ajoute 1 et nb devient = 1 sinon 0 et nb reste égal à 0, ensuite il regarde la deuxième lettre et fait pareil, etc .
    Par contre, il serait bon que tu fasses un peu de recherches sur les fonctions avec google, il y a pas mal de sites intéressants sur VB, par exemple : https://www.microsoft.com/en-us/download/details.aspx?id=55984
    Bonne nuit
    0
  17. mariem
     
    Public Class Form1
    Dim k As Integer

    Dim mot As String
    ---------

    Private Sub btn_dec_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_dec.Click

    mot = txt_mot.Text
    For k = 0 To (mot.Length.ToString) - 1

    Liste_mot.Items.Add(mot.Substring(k, 1))
    Next
    txt_mot.Text = ""

    End Sub

    -------
    Private Sub btn_pal_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_pal.Click

    If Liste_mot.Items.Count = StrReverse(Liste_mot.Items.Count) Then
    MsgBox("Il s'agit d'un palindrome")
    Else
    MsgBox("ce mot n'est pas un palindrome")
    End If

    Liste_mot.Items.Clear()
    End Sub
    End Class
    0
    1. meryemKsr
       
      Private Sub CmdPalindrome_Click()
      Dim leMot, word As String
      leMot = Text1.Text
      motsansespace = ""


      For i = 1 To Len(leMot)
      word = Mid(leMot, i, 1)
      If word <> " " Then
      motsansespace = motsansespace & LCase(word)
      End If
      Next i
      'MsgBox motsansespace
      'MsgBox StrReverse(motsansespace)

      If LCase(motsansespace) = LCase(StrReverse(motsansespace)) Then
      MsgBox "Il s'agit d'un palindrome"
      Else
      MsgBox "Il ne s'agit pas d'un palindrome"
      End If
      0
    2. dodita
       
      merci bq pour tt le monde votre commmentaire ma aider bq a devolope mon information
      0
  18. help
     
    Bonjour

    j'ai un problème concernant un programme à faire en VBA : générer un palindrome et je ne sais pas comment m'y prendre!!

    merci de votre aide!!
    -1
    1. palindrom
       
      g du mal aussi à générer un palindrome en VBA!!
      si quelqu'un sait ça serait génial!!
      0