IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Suppression blanc début item


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 469
    Points : 149
    Points
    149
    Par défaut Suppression blanc début item
    Bonjour,

    Le but du code ci dessous est de permuter le nom d'un fichier AAAA - BBB en BBB - AAAA.
    Le problème c'est qu'il y a un caractère blanc devant BBB après permutation.

    Quelqu'un pourrait-il me conseiller ?

    Un grand merci d'avance.

    Habiler

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    Sub Perm_Mat_Name()
     
    Dim OldFolderName, NewFolderName As String
    Dim objFileSystem As Object
     Dim newName As String
     Dim newNameSplit As String
     Dim splitMatrNom() As String
     
    Set objFSO = New FileSystemObject
    Set mysource = objFSO.GetFolder("C:\PERS")
    Set objFileSystem = CreateObject("Scripting.FileSystemObject")
     
        Dim i As Long
        For Each Folder In mysource.SubFolders
     
     
        splitMatrNom = Split(Folder.Name, "-")
      '  Debug.Print splitMatrNom(1)
     
          'For i = LBound(splitMatrNom) To UBound(splitMatrNom)
         newNameSplit = splitMatrNom(1) & " - " & splitMatrNom(0)
         Debug.Print newNameSplit
            If Folder.Name <> newName Then Folder.Name = newNameSplit
            'Next i
        Next Folder
     
    End Sub

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 759
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 759
    Points : 28 611
    Points
    28 611
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    C'est tout à fait normal qu'il y a ait des caractères espacés de trop puisque ce qui sépare les deux mots est un trigramme " - " or vous utilisé la fonction Split avec comme second argument un tiret, il faudrait donc choisir " - "

    Exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub t()
      Dim t As Variant
      Dim n As String
      n = "AAA - BBB"
      t = Split(n, " - ")
      n = t(1) & " - " & t(0)
      Debug.Print n
    End Sub
    [EDIT]
    Autre exemple où l'on supprime tous les caractères espacés avant de construire la table avec la fonction Split
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub t()
      Dim t As Variant
      Dim n As String
      n = Trim(Replace("AAA - BBB", " ", ""))
      t = Split(n, "-")
      n = t(1) & " - " & t(0)
      Debug.Print n
    End Sub
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 100
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 100
    Points : 1 621
    Points
    1 621
    Par défaut
    3e option, on passe par les regex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim Data As String
    Data = "AAAA - BBBB"
     
    Dim Rx As Object    '// VbScript.RegExp
    Set Rx = CreateObject("VbScript.RegExp")
    Rx.Pattern = "(.*) - (.*)"
    Data = Rx.Replace(Data, "$2 - $1")

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 469
    Points : 149
    Points
    149
    Par défaut
    Merci pour vos réponses rapides.

    Mais j'ai perdu de vue que mon code tournait en boucle. il recommence l'opération en sens inverse une fois la 1ére permutation effectuée.

    j'essaie avec la fonction is numeric pour ne traiter que les folders commencant par un chiffre mais je me plante.

  5. #5
    Expert éminent
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    3 949
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 3 949
    Points : 9 277
    Points
    9 277
    Par défaut
    Hello,
    Citation Envoyé par HABILER Voir le message
    Mais j'ai perdu de vue que mon code tournait en boucle. il recommence l'opération en sens inverse une fois la 1ére permutation effectuée.
    tournait en boucle ? c'est à dire ?
    Avec ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub Perm_Mat_Name()
    Dim OldFolderName, NewFolderName As String
    Dim objFSO As Object, mysource As Object, Folder As Object
    Dim newName As String, newNameSplit As String, splitMatrNom() As String
     
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    Set mysource = objFSO.GetFolder("D:\Test\Pers")
    For Each Folder In mysource.SubFolders
        splitMatrNom = Split(Folder.Name, " - ")
        newNameSplit = splitMatrNom(1) & " - " & splitMatrNom(0)
        Debug.Print newNameSplit
        If Folder.Name <> newName Then Folder.Name = newNameSplit
        Next Folder
    End Sub
    et avec AAAA - BBB et CCCC - DDD dans le répertoire D:\Test\Pers
    j'obtiens ceci sans qu'il n'y ait de rebouclage :

    Nom : SwapNames.png
Affichages : 60
Taille : 3,3 Ko

    Ami calmant, J.P
    Jurassic computer : Sinclair ZX81 - Zilog Z80A à 3,25 MHz - RAM 1 Ko - ROM 8 Ko

Discussions similaires

  1. Suppression blanc champ
    Par Ljosse dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 12/11/2008, 19h37
  2. Gets & puts : suppression blancs fin de ligne
    Par HRS dans le forum Tcl/Tk
    Réponses: 1
    Dernier message: 20/09/2008, 20h23
  3. suppression d'un item d'un CtrlList
    Par moon93 dans le forum wxPython
    Réponses: 1
    Dernier message: 13/08/2007, 10h50
  4. [VB.NET] Suppression d'un item dans une listview
    Par Remedy dans le forum Windows Forms
    Réponses: 5
    Dernier message: 17/07/2006, 16h00
  5. [C#] Suppression d'un item dans une listview
    Par Popof dans le forum Windows Forms
    Réponses: 6
    Dernier message: 15/04/2006, 13h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo