Accéder au contenu principal

Kutools for Office — Une Suite. Cinq Outils. Accomplissez Plus.

Comment calculer l'âge avant le 1/1/1900 dans Excel ?

Author Sun Last modified

Dans Excel, les dates antérieures au 1/1/1900 ne peuvent pas être saisies ni calculées correctement. Si vous souhaitez calculer l'âge d'une personne née et décédée avant le 1/1/1900, il serait généralement impossible d'obtenir un calcul correct dans Excel. Cependant, dans cet article, une astuce peut vous aider à calculer l'âge avant le 1/1/1900 dans Excel.

Calculer l'âge avant le 1/1/1900 avec VBA

Calculer l'âge par date de naissance avec Kutools pour Excel good idea3


arrow blue right bubble Calculer l'âge avant le 1/1/1900 avec VBA

Voici un code VBA qui peut vous aider à calculer rapidement l'âge avant le 1/1/1900.

1. Sélectionnez une cellule vide et entrez la date de naissance de la personne, puis sélectionnez une autre cellule pour entrer la date du jour ou la date de décès selon vos besoins. Voir capture d'écran :
sample data

2. Appuyez ensuite sur Alt + F11 pour ouvrir la fenêtre Microsoft Visual Basic pour Applications.

3. Cliquez sur Insertion > Module, puis collez le code VBA ci-dessous dans la nouvelle fenêtre Module.

VBA : Calculer l'âge avant le 1/1/1900

Public Function AgeFunc(SDate As Variant, EDate As Variant) As Long
'UpdatebyExtendOffice20160429
    Dim xSMonth As Integer
    Dim xSDay As Integer
    Dim xSYear As Integer
    Dim xEMonth As Integer
    Dim xEDay As Integer
    Dim xEYear As Integer
    Dim xAge As Integer
    If Not GetDate(SDate, xSYear, xSMonth, xSDay) Then
        AgeFunc = "Invalid Date"
        Exit Function
    End If
    If Not GetDate(EDate, xEYear, xEMonth, xEDay) Then
        AgeFunc = "Invalid Date"
        Exit Function
    End If
    xAge = xEYear - xSYear
    If xSMonth > xEMonth Then
        xAge = xAge - 1
    ElseIf xSMonth = xEMonth Then
        If xSDay > xEDay Then xAge = xAge - 1
    End If
    If xAge < 0 Then
        AgeFunc = "Invalid Date"
    Else
        AgeFunc = xAge
    End If
End Function

Private Function GetDate(ByVal DateStr As String, Y As Integer, M As Integer, D As Integer) As Boolean
    Dim I As Long
    Dim K As Long
    Y = 0
    M = 0
    D = 0
    GetDate = True
    On Error Resume Next
    I = InStr(1, DateStr, "/")
    M = CLng(Left(DateStr, I - 1))
    D = CLng(Mid(DateStr, I + 1, InStr(I + 1, DateStr, "/") - I - 1))
    Y = CLng(Right(DateStr, Len(DateStr) - InStrRev(DateStr, "/")))
    If M < 1 Or M > 12 Or D < 1 Or D > 31 Or Y < 1 Then
        GetDate = False
    End If
End Function

4. Sélectionnez une cellule vide, ici C2, et entrez cette formule =AgeFunc(A2,B2) (A2 est la date de naissance, et B2 est la date de fin), puis appuyez sur Entrée pour obtenir l'âge, et faites glisser la poignée de recopie automatique sur les cellules dont vous avez besoin. Voir capture d'écran :
apply user defined function to get the result

Remarque : Ce VBA ne peut calculer les âges qu'avec des dates au format mm/jj/aaaa, comme 23/6/1845.


arrow blue right bubble Calculer l'âge par date de naissance avec Kutools pour Excel

Si les dates de naissance sont normalement postérieures au 1/1/1900, vous pouvez appliquer l'utilitaire d'aide Date et heure de Kutools pour Excel, qui peut rapidement calculer l'âge à partir des dates de naissance fournies.

Kutools pour Excel propose plus de 300 fonctionnalités avancées pour simplifier les tâches complexes, augmentant ainsi la créativité et l'efficacité. Intégré à des capacités d'IA, Kutools automatise les tâches avec précision, rendant la gestion des données facile et sans effort. Informations détaillées sur Kutools pour Excel...  Essai gratuit...

Après avoir installé gratuitement Kutools pour Excel, veuillez procéder comme suit :

1. Sélectionnez une cellule vide où vous souhaitez afficher l'âge, puis cliquez sur Kutools > Assistant de formule > Date et heure helper. Voir capture d'écran :
 click Date & Time helper feature of kutools

2. Ensuite, dans la Date et heure helper boîte de dialogue, cochez l'option Âge, sélectionnez la date de naissance sur laquelle vous souhaitez baser le calcul de l'âge dans la zone de texte Date de naissance Par défaut, la cellule sera sélectionnée en référence absolue, mais vous pouvez la changer en référence relative, puis cochez l'option Aujourd'hui et choisissez un type de résultat que vous souhaitez afficher dans la liste déroulante Type de résultat de sortie. Voir capture d'écran :
specify options in the dialog box

3. Cliquez sur Ok pour appliquer cette formule, et maintenant vous pouvez voir que l'âge est affiché. Et si nécessaire, vous pouvez faire glisser la poignée de recopie automatique sur les cellules nécessitant cette formule. Voir capture d'écran :
the age has been calculated

Meilleurs outils de productivité pour Office

🤖 Kutools AI Aide : Révolutionnez l'analyse de données avec : Exécution intelligente | Générer du code | Créer des formules personnalisées | Analyser des données et générer des graphiques | Appeler les Fonctions améliorées de Kutools
Fonctionnalités populaires : Trouver, mettre en évidence ou marquer les doublons | Supprimer les lignes vides | Combinez les colonnes ou les cellules sans perte de données | Arrondir sans formule...
Super RECHERCHEV : Recherche multi-critères | Recherche multi-valeurs | Recherche multi-feuilles | Correspondance floue...
Liste déroulante avancée : Créer rapidement une liste déroulante | Liste déroulante dépendante | Liste déroulante à sélection multiple...
Gestionnaire de colonnes : Ajouter un nombre spécifique de Colonnes | Déplacer des Colonnes | Alterner l’état de visibilité des Colonnes masquées | Comparer des plages & Colonnes...
Fonctionnalités phares : Mise au point de la grille | Affichage de conception | Barre de formule améliorée | Gestionnaire de Classeur & Feuille de calcul | Bibliothèque d’AutoTexte | Sélecteur de date | Merge Worksheets | Chiffrer/Déchiffrer les cellules | Envoyer un e-mail par liste | Super Filtre | Filtre spécial (filtrer les cellules avec une police en gras/italique/barré...)...
Top15 des ensembles d’outils :12 outils de texte (Ajouter du texte, Supprimer des caractères spécifiques, ...) |50+ Types de graphiques (Diagramme de Gantt, ...) |40+ Formules pratiques (Calculer l’âge en fonction de la date de naissance, ...) |19 outils d’insertion (Insérer un code QR, Insérer une image depuis le chemin, ...) |12 outils de conversion (Convertir en mots, Conversion de devises, ...) |7 outils de fusion & division (Fusion avancée des lignes, Diviser les cellules, ...) | ... et bien plus encore
Utilisez Kutools dans la langue de votre choix – disponible en Anglais, Espagnol, Allemand, Français, Chinois et plus de40 autres !

Améliorez vos compétences Excel avec Kutools pour Excel, et découvrez une efficacité incomparable. Kutools pour Excel propose plus de300 fonctionnalités avancées pour booster votre productivité et gagner du temps. Cliquez ici pour obtenir la fonctionnalité dont vous avez le plus besoin...


Office Tab apporte l’interface par onglets à Office, simplifiant considérablement votre travail.

  • Activez la modification et la lecture par onglets dans Word, Excel, PowerPoint, Publisher, Access, Visio et Project.
  • Ouvrez et créez plusieurs documents dans de nouveaux onglets de la même fenêtre, plutôt que dans de nouvelles fenêtres.
  • Augmente votre productivité de50 % et réduit des centaines de clics de souris chaque jour !

Tous les modules complémentaires Kutools. Une seule installation

La suite Kutools for Office regroupe les modules complémentaires pour Excel, Word, Outlook & PowerPoint ainsi qu’Office Tab Pro, idéal pour les équipes travaillant sur plusieurs applications Office.

Excel Word Outlook Tabs PowerPoint
  • Suite tout-en-un — modules complémentaires Excel, Word, Outlook & PowerPoint + Office Tab Pro
  • Un installateur, une licence — installation en quelques minutes (compatible MSI)
  • Une synergie optimale — productivité accélérée sur l’ensemble des applications Office
  • Essai complet30 jours — sans inscription, ni carte bancaire
  • Meilleure valeur — économisez par rapport à l’achat d’add-ins individuels