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 :

Copier Coller Date qui ne marche pas [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Novembre 2014
    Messages : 77
    Par défaut Copier Coller Date qui ne marche pas
    Bonjour,

    Je comprends pas pourquoi mon code de copier coller (en rouge D1=> K1) une date, ne marche pas, pourtant tout semble OK ?

    Pouvez vous m'aider svp ?


    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
    28
    29
    30
    Sub TraitementSheet(Sh As Worksheet)
    Dim Plage As Range
    Dim Cel As Range
     
      Range("D1").Copy
     Range("K1").Activate
     ActiveSheet.Paste
    
     If UCase(Left(Sh.Name, 5)) <> UCase("Valor") Then Exit Sub
    
    Set Plage = Sh.Range(Sh.Cells(2, 1), Sh.Cells(Sh.Rows.Count, 1).End(xlUp))
    
    For Each Cel In Plage
        'Condition 1) Si colonne A, B, non vide et si colonne F est en % alors copier E dans G
     
        If Trim("" & Cel.Value) <> "" And Trim("" & Cel.Offset(0, 1).Value) <> "" And Trim("" & Cel.Offset(0, 5).NumberFormat) = "0.00%" Then
            Cel.Offset(, 10).Value = Cel.Offset(, 6).Value
     
        'Condition 2 ) Si colonne A, B, non vide, et si colonne F n'est pas en % alors copier F dans G
        ElseIf Cel.Value <> "" And Cel.Offset(0, 1).Value <> "" And Cel.Offset(0, 5).NumberFormat <> "0%" Then
            Cel.Offset(, 10).Value = Cel.Offset(, 5).Value
            
    
     
        End If
     
    
    Next
    End Sub
    Merci beaucoup.

    Cordialement,

  2. #2
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 128
    Par défaut
    Bonjour,

    Pourquoi écrire 3 lignes de code dégueulasses quand on peut en faire qu'une propre ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("D1").Copy Destination:=Range("K1")
    Surtout que sur le web il y a déjà des tonnes de sujet qui répondent à ça !

    Slooby

  3. #3
    Membre confirmé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Novembre 2014
    Messages : 77
    Par défaut
    J'ai tout essayé sur le net ! Dont le tiens qui ne marche pas ! Pourtant ca marche pas .... Voici le code complet :


    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    Option Explicit
    Sub Test()
    Dim Plage As Range, InpRng As Range
    Dim Cel As Range
    'On Error GoTo Err_Read
    Dim Derl As Long
    Derl = ThisWorkbook.Worksheets("Mensuel").Range("A" & Cells.Rows.Count).End(xlUp).Row
    Set InpRng = ThisWorkbook.Worksheets("Mensuel").Range("A2:A" & Derl)
    Debug.Print InpRng.Address, InpRng.Cells.Count
    For Each Cel In InpRng
        If Trim("" & Cel) <> "" Then Histo CStr(Cel) Else MsgBox Cel.Address & " invalide"
    Next
    End Sub
    Sub Histo(Fichier As String)
    Dim Sh As Worksheet
    Dim wb As Workbook
    Application.DisplayAlerts = False
    Set wb = Workbooks.Open(Fichier)
    Application.DisplayAlerts = True
    For Each Sh In wb.Sheets
        TraitementSheet Sh
    Next
    wb.Save
    wb.Close
    End Sub
    Sub TraitementSheet(Sh As Worksheet)
    Dim Plage As Range
    Dim Cel As Range
     
    Range("D1").Copy Destination:=Range("K1")
    
     If UCase(Left(Sh.Name, 5)) <> UCase("Valor") Then Exit Sub
    
    Set Plage = Sh.Range(Sh.Cells(2, 1), Sh.Cells(Sh.Rows.Count, 1).End(xlUp))
    
    For Each Cel In Plage
        'Condition 1) Si colonne A, B, non vide et si colonne F est en % alors copier E dans G
     
        If Trim("" & Cel.Value) <> "" And Trim("" & Cel.Offset(0, 1).Value) <> "" And Trim("" & Cel.Offset(0, 5).NumberFormat) = "0.00%" Then
            Cel.Offset(, 10).Value = Cel.Offset(, 6).Value
     
        'Condition 2 ) Si colonne A, B, non vide, et si colonne F n'est pas en % alors copier F dans G
        ElseIf Cel.Value <> "" And Cel.Offset(0, 1).Value <> "" And Cel.Offset(0, 5).NumberFormat <> "0%" Then
            Cel.Offset(, 10).Value = Cel.Offset(, 5).Value
            
    
     
        End If
     
    
    Next
    End Sub

  4. #4
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 128
    Par défaut
    Et avec:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sh.Range("D1").Copy Destination:=Sh.Range("K1")
    ça donne quoi ?

    J'ai déjà eu des erreurs de copié/collé avec l'objet WorkSheet.
    Dans le PIRE des cas (à faire le moins souvent possible !!!), active ta feuille avant de faire ton copié/collé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Sh.Activate
    Range("D1").Copy Destination:=Range("K1")
    Slooby

  5. #5
    Membre confirmé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Novembre 2014
    Messages : 77
    Par défaut
    Merci beaucoup !!!
    Ca marche 100% parfait

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. copier coller sur photoshop cs5 marche pas
    Par mouss4rs dans le forum Imagerie
    Réponses: 10
    Dernier message: 10/10/2010, 22h31
  2. fonction date() qui ne marche pas
    Par Décibel dans le forum Runtime
    Réponses: 11
    Dernier message: 03/08/2010, 20h36
  3. Copier coller qui ne marche pas d'un classeur à un autre
    Par longuy31 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 25/06/2010, 12h02
  4. [XL-2000] macro copier coller avec condition ne marche pas
    Par antfo dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 17/03/2010, 10h54
  5. [E-07] Copier/Coller qui ne marche pas
    Par bdx-77 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 26/12/2008, 07h00

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