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 :

[E-07] Changer le format de ma cellule


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    325
    Détails du profil
    Informations personnelles :
    Localisation : France, Morbihan (Bretagne)

    Informations forums :
    Inscription : Mars 2008
    Messages : 325
    Par défaut [E-07] Changer le format de ma cellule
    Bonjour

    Mon problème : J'ai une fonction qui renvoie une date. La valeur de la cellule est un entier, je suis obligé de changer le format de la cellule manuellement(clique droit, format de la cellule, date), j'aimerai faire ça par programmation?

    voici le code de ma fonction :
    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
    54
    55
    56
    57
    58
    59
    Public Function CDateDebEx(Optional Exercice As Integer = 0) As Variant
        Application.ScreenUpdating = False
        Dim DateDeb As Variant
        Dim ChaineDate As String
        Dim Liste As String
            
        Dim DateDossierDeb As ADODB.Recordset
        Set DateDossierDeb = New ADODB.Recordset
        
        If Exercice < -5 Or Exercice > 0 Then
            Application.ScreenUpdating = True
            CDateDebEx = CVErr(xlErrValue)
            Exit Function
        End If
        
        ChaineDate = "DDATEDEBN"
        Select Case Exercice
                Case -5
                    ChaineDate = ChaineDate + "5"
                
                Case -4
                    ChaineDate = ChaineDate + "4"
                    
                Case -3
                    ChaineDate = ChaineDate + "3"
                    
                Case -2
                    ChaineDate = ChaineDate + "2"
                    
                Case -1
                    ChaineDate = ChaineDate + "1" 'CDate(DateDossierDeb("DDATEDEBN1"))
                    
                Case 0
                    ChaineDate = ChaineDate
        End Select
        
        Liste = "SELECT " & ChaineDate & " FROM Dossier "
        DateDossierDeb.Open Liste, ConnCACAO, adOpenStatic, adLockReadOnly
    
        If DateDossierDeb.EOF = True Then
            CDateDebEx = CVErr(xlErrValue)
        Else
            DateDeb = DateDossierDeb(ChaineDate)
            If IsNull(DateDeb) Then
                CDateDebEx = ""
            Else
                CDateDebEx = DateDeb
            End If
        End If
    
        Si le format de ma cellule est un standart ou un nombre ou un texte alors
           le format de ma cellule est une date
        fin
    
        DateDossierDeb.Close
        Set DateDossierDeb = Nothing
        Application.ScreenUpdating = True
    End Function
    en rouge la valeur que a fonction retourne
    exemple fx=CDateDebEx()
    CDateDebEx=01/01/2008 et la valeur afficher de ma cellule est égale a 39448

    en bleu ce que je vroudrai faire. D'une est ce que cela est possible, si comment?

    cordialement law56100

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonsoir,

    ta cellule = format(variable,"dd/mm/yyyy")
    Je pense comme çà
    a +
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    325
    Détails du profil
    Informations personnelles :
    Localisation : France, Morbihan (Bretagne)

    Informations forums :
    Inscription : Mars 2008
    Messages : 325
    Par défaut
    J'ai essaye mais cela ne fonctionne pas
    j'ai aussi essayé cela et ca ne fonctionne pas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        ActiveCell.NumberFormatLocal = "jj/mm/aa"
        ActiveCell.NumberFormat = "dd/mm/yy"

    J'ai essaié cela sa fonctionne a moitié, cela change bien mon resultat mais il m'est après impossible de la changer manuellement mais comment testé si la cellule est en format entier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     CDateDebEx = Format(CDate(Day(DateDeb) & "/" & Month(DateDeb) & "/" & Year(DateDeb)), "dd/mm/yyyy")

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

Discussions similaires

  1. [XL-2007] VBA changer de format d'une cellule
    Par james6006 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 27/02/2014, 08h34
  2. Changer le format d'une cellule excel
    Par SonnyFab dans le forum ASP.NET
    Réponses: 6
    Dernier message: 09/09/2010, 14h27
  3. Réponses: 1
    Dernier message: 19/04/2008, 22h39
  4. [VBA-E]changer le format d'une cellule dans un spreadsheet
    Par delamarque dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 13/02/2006, 11h12
  5. [VBA-E] Changer un format de cellule
    Par Squelet dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 06/02/2006, 17h36

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