c# - récupérer - comment calculer l année de naissance




Comment calculer l'âge de quelqu'un en C#? (20)

C’est l’une des réponses les plus précises pouvant résoudre l’anniversaire du 29 février par rapport à toute année du 28 février.

public int GetAge(DateTime birthDate)
{
    int age = DateTime.Now.Year - birthDate.Year;

    if (birthDate.DayOfYear > DateTime.Now.DayOfYear)
        age--;

    return age;
}

Étant donné qu'un DateTime représente l'anniversaire d'une personne, comment puis-je calculer son âge en années?


Ce n'est pas une réponse directe, mais plutôt un raisonnement philosophique sur le problème en question d'un point de vue quasi scientifique.

Je dirais que la question ne précise pas l'unité ou la culture dans laquelle mesurer l'âge, la plupart des réponses semblent supposer une représentation annuelle entière. L'unité SI du temps est second la bonne réponse générique (devrait bien entendu être normalisée DateTime et ne pas tenir compte des effets relativistes):

var lifeInSeconds = (DateTime.Now.Ticks - then.Ticks)/TickFactor;

Dans le calcul chrétien de l'âge en années:

var then = ... // Then, in this case the birthday
var now = DateTime.UtcNow;
int age = now.Year - then.Year;
if (now.AddYears(-age) < then) age--;

En finance, le calcul d'un calcul souvent appelé fraction journalière , pose un problème similaire , qui correspond approximativement à un nombre d'années pour une période donnée. Et la question de l’âge est vraiment une question de mesure du temps.

Exemple de convention réelle / réelle (en comptant tous les jours "correctement"):

DateTime start, end = .... // Whatever, assume start is before end

double startYearContribution = 1 - (double) start.DayOfYear / (double) (DateTime.IsLeapYear(start.Year) ? 366 : 365);
double endYearContribution = (double)end.DayOfYear / (double)(DateTime.IsLeapYear(end.Year) ? 366 : 365);
double middleContribution = (double) (end.Year - start.Year - 1);

double DCF = startYearContribution + endYearContribution + middleContribution;

Une autre façon assez courante de mesurer le temps consiste généralement à "sérialiser" (le mec qui a nommé cette convention de date doit avoir sérieusement trippé '):

DateTime start, end = .... // Whatever, assume start is before end
int days = (end - start).Days;

Je me demande combien de temps il nous reste avant qu'un âge relativiste en secondes ne devienne plus utile que l'approximation approximative des cycles terre-ensoleillement au cours de sa vie jusqu'à présent :) Ou, en d'autres termes, quand une fonction représentant le mouvement pour qu'il soit valide :)


J'ai une méthode personnalisée pour calculer l'âge, ainsi qu'un message de validation des bonus au cas où cela aiderait:

public void GetAge(DateTime dob, DateTime now, out int years, out int months, out int days)
{
    years = 0;
    months = 0;
    days = 0;

    DateTime tmpdob = new DateTime(dob.Year, dob.Month, 1);
    DateTime tmpnow = new DateTime(now.Year, now.Month, 1);

    while (tmpdob.AddYears(years).AddMonths(months) < tmpnow)
    {
        months++;
        if (months > 12)
        {
            years++;
            months = months - 12;
        }
    }

    if (now.Day >= dob.Day)
        days = days + now.Day - dob.Day;
    else
    {
        months--;
        if (months < 0)
        {
            years--;
            months = months + 12;
        }
        days += DateTime.DaysInMonth(now.AddMonths(-1).Year, now.AddMonths(-1).Month) + now.Day - dob.Day;
    }

    if (DateTime.IsLeapYear(dob.Year) && dob.Month == 2 && dob.Day == 29 && now >= new DateTime(now.Year, 3, 1))
        days++;

}   

private string ValidateDate(DateTime dob) //This method will validate the date
{
    int Years = 0; int Months = 0; int Days = 0;

    GetAge(dob, DateTime.Now, out Years, out Months, out Days);

    if (Years < 18)
        message =  Years + " is too young. Please try again on your 18th birthday.";
    else if (Years >= 65)
        message = Years + " is too old. Date of Birth must not be 65 or older.";
    else
        return null; //Denotes validation passed
}

La méthode appelle ici et transmet la valeur datetime (MM / jj / aaaa si le serveur est défini sur les paramètres régionaux USA). Remplacez-le par n'importe quoi, une boîte de message ou un conteneur à afficher:

DateTime dob = DateTime.Parse("03/10/1982");  

string message = ValidateDate(dob);

lbldatemessage.Visible = !StringIsNullOrWhitespace(message);
lbldatemessage.Text = message ?? ""; //Ternary if message is null then default to empty string

N'oubliez pas que vous pouvez formater le message comme bon vous semble.


J'ai utilisé la solution de ScArcher2 pour un calcul précis de l'âge d'une personne, mais je devais l'approfondir et calculer leurs mois et jours avec les années.

    public static Dictionary<string,int> CurrentAgeInYearsMonthsDays(DateTime? ndtBirthDate, DateTime? ndtReferralDate)
    {
        //----------------------------------------------------------------------
        // Can't determine age if we don't have a dates.
        //----------------------------------------------------------------------
        if (ndtBirthDate == null) return null;
        if (ndtReferralDate == null) return null;

        DateTime dtBirthDate = Convert.ToDateTime(ndtBirthDate);
        DateTime dtReferralDate = Convert.ToDateTime(ndtReferralDate);

        //----------------------------------------------------------------------
        // Create our Variables
        //----------------------------------------------------------------------
        Dictionary<string, int> dYMD = new Dictionary<string,int>();
        int iNowDate, iBirthDate, iYears, iMonths, iDays;
        string sDif = "";

        //----------------------------------------------------------------------
        // Store off current date/time and DOB into local variables
        //---------------------------------------------------------------------- 
        iNowDate = int.Parse(dtReferralDate.ToString("yyyyMMdd"));
        iBirthDate = int.Parse(dtBirthDate.ToString("yyyyMMdd"));

        //----------------------------------------------------------------------
        // Calculate Years
        //----------------------------------------------------------------------
        sDif = (iNowDate - iBirthDate).ToString();
        iYears = int.Parse(sDif.Substring(0, sDif.Length - 4));

        //----------------------------------------------------------------------
        // Store Years in Return Value
        //----------------------------------------------------------------------
        dYMD.Add("Years", iYears);

        //----------------------------------------------------------------------
        // Calculate Months
        //----------------------------------------------------------------------
        if (dtBirthDate.Month > dtReferralDate.Month)
            iMonths = 12 - dtBirthDate.Month + dtReferralDate.Month - 1;
        else
            iMonths = dtBirthDate.Month - dtReferralDate.Month;

        //----------------------------------------------------------------------
        // Store Months in Return Value
        //----------------------------------------------------------------------
        dYMD.Add("Months", iMonths);

        //----------------------------------------------------------------------
        // Calculate Remaining Days
        //----------------------------------------------------------------------
        if (dtBirthDate.Day > dtReferralDate.Day)
            //Logic: Figure out the days in month previous to the current month, or the admitted month.
            //       Subtract the birthday from the total days which will give us how many days the person has lived since their birthdate day the previous month.
            //       then take the referral date and simply add the number of days the person has lived this month.

            //If referral date is january, we need to go back to the following year's December to get the days in that month.
            if (dtReferralDate.Month == 1)
                iDays = DateTime.DaysInMonth(dtReferralDate.Year - 1, 12) - dtBirthDate.Day + dtReferralDate.Day;       
            else
                iDays = DateTime.DaysInMonth(dtReferralDate.Year, dtReferralDate.Month - 1) - dtBirthDate.Day + dtReferralDate.Day;       
        else
            iDays = dtReferralDate.Day - dtBirthDate.Day;             

        //----------------------------------------------------------------------
        // Store Days in Return Value
        //----------------------------------------------------------------------
        dYMD.Add("Days", iDays);

        return dYMD;
}

La façon la plus simple que j'ai jamais trouvée est la suivante. Cela fonctionne correctement pour les paramètres régionaux des États-Unis et de l'Europe occidentale. Je ne peux pas parler à d'autres endroits, en particulier à des endroits comme la Chine. 4 extra supplémentaires, tout au plus, après le calcul initial de l'âge.

public int AgeInYears(DateTime birthDate, DateTime referenceDate)
{
  Debug.Assert(referenceDate >= birthDate, 
               "birth date must be on or prior to the reference date");

  DateTime birth = birthDate.Date;
  DateTime reference = referenceDate.Date;
  int years = (reference.Year - birth.Year);

  //
  // an offset of -1 is applied if the birth date has 
  // not yet occurred in the current year.
  //
  if (reference.Month > birth.Month);
  else if (reference.Month < birth.Month) 
    --years;
  else // in birth month
  {
    if (reference.Day < birth.Day)
      --years;
  }

  return years ;
}

Je parcourais les réponses à cette question et remarquai que personne n’avait fait référence aux implications réglementaires / juridiques des naissances par jour bissextile. Par exemple, selon Wikipedia , si vous êtes né le 29 février dans différentes juridictions, votre date de naissance n'est pas d'une année bissextile, elle varie:

  • Au Royaume-Uni et à Hong Kong: c'est le jour ordinal de l'année, donc le lendemain, le 1er mars est votre anniversaire.
  • En Nouvelle-Zélande: c'est la veille, le 28 février pour les permis de conduire et le 1er mars pour les autres raisons.
  • Taiwan: c'est le 28 février.

Et pour autant que je sache, aux États-Unis, les lois sont muettes sur le sujet, laissant à la common law le soin de définir comment les divers organismes de réglementation définissent les choses dans leurs règlements.

À cette fin, une amélioration:

public enum LeapDayRule
{
  OrdinalDay     = 1 ,
  LastDayOfMonth = 2 ,
}

static int ComputeAgeInYears(DateTime birth, DateTime reference, LeapYearBirthdayRule ruleInEffect)
{
  bool isLeapYearBirthday = CultureInfo.CurrentCulture.Calendar.IsLeapDay(birth.Year, birth.Month, birth.Day);
  DateTime cutoff;

  if (isLeapYearBirthday && !DateTime.IsLeapYear(reference.Year))
  {
    switch (ruleInEffect)
    {
      case LeapDayRule.OrdinalDay:
        cutoff = new DateTime(reference.Year, 1, 1)
                             .AddDays(birth.DayOfYear - 1);
        break;

      case LeapDayRule.LastDayOfMonth:
        cutoff = new DateTime(reference.Year, birth.Month, 1)
                             .AddMonths(1)
                             .AddDays(-1);
        break;

      default:
        throw new InvalidOperationException();
    }
  }
  else
  {
    cutoff = new DateTime(reference.Year, birth.Month, birth.Day);
  }

  int age = (reference.Year - birth.Year) + (reference >= cutoff ? 0 : -1);
  return age < 0 ? 0 : age;
}

Il convient de noter que ce code suppose:

  • Un calcul occidental (européen) de l'âge, et
  • Un calendrier, comme le calendrier grégorien, qui insère un seul jour bissextile à la fin du mois.

Que diriez-vous de cette solution?

static string CalcAge(DateTime birthDay)
{
    DateTime currentDate = DateTime.Now;         
    int approximateAge = currentDate.Year - birthDay.Year;
    int daysToNextBirthDay = (birthDay.Month * 30 + birthDay.Day) - 
        (currentDate.Month * 30 + currentDate.Day) ;

    if (approximateAge == 0 || approximateAge == 1)
    {                
        int month =  Math.Abs(daysToNextBirthDay / 30);
        int days = Math.Abs(daysToNextBirthDay % 30);

        if (month == 0)
            return "Your age is: " + daysToNextBirthDay + " days";

        return "Your age is: " + month + " months and " + days + " days"; ;
    }

    if (daysToNextBirthDay > 0)
        return "Your age is: " + --approximateAge + " Years";

    return "Your age is: " + approximateAge + " Years"; ;
}

Voici une solution.

DateTime dateOfBirth = new DateTime(2000, 4, 18);
DateTime currentDate = DateTime.Now;

int ageInYears = 0;
int ageInMonths = 0;
int ageInDays = 0;

ageInDays = currentDate.Day - dateOfBirth.Day;
ageInMonths = currentDate.Month - dateOfBirth.Month;
ageInYears = currentDate.Year - dateOfBirth.Year;

if (ageInDays < 0)
{
    ageInDays += DateTime.DaysInMonth(currentDate.Year, currentDate.Month);
    ageInMonths = ageInMonths--;

    if (ageInMonths < 0)
    {
        ageInMonths += 12;
        ageInYears--;
    }
}

if (ageInMonths < 0)
{
    ageInMonths += 12;
    ageInYears--;
}

Console.WriteLine("{0}, {1}, {2}", ageInYears, ageInMonths, ageInDays);

2 Les principaux problèmes à résoudre sont:

1. Calculez l'âge exact - en années, mois, jours, etc.

2. Calculez l'âge généralement perçu - les gens ne se soucient généralement pas de leur âge, ils se soucient juste de la date de leur anniversaire dans l'année en cours.

La solution pour 1 est évidente:

DateTime birth = DateTime.Parse("1.1.2000");
DateTime today = DateTime.Today;     //we usually don't care about birth time
TimeSpan age = today - birth;        //.NET FCL should guarantee this as precise
double ageInDays = age.TotalDays;    //total number of days ... also precise
double daysInYear = 365.2425;        //statistical value for 400 years
double ageInYears = ageInDays / daysInYear;  //can be shifted ... not so precise

La solution pour 2 est celle qui n’est pas aussi précise dans la détermination de l’âge total, mais qui est perçue comme telle par les gens. Les gens l'utilisent aussi généralement lorsqu'ils calculent leur âge "manuellement":

DateTime birth = DateTime.Parse("1.1.2000");
DateTime today = DateTime.Today;
int age = today.Year - birth.Year;    //people perceive their age in years

if (today.Month < birth.Month ||
   ((today.Month == birth.Month) && (today.Day < birth.Day)))
{
  age--;  //birthday in current year not yet reached, we are 1 year younger ;)
          //+ no birthday for 29.2. guys ... sorry, just wrong date for birth
}

Notes à 2 .:

  • C'est ma solution préférée
  • Nous ne pouvons pas utiliser DateTime.DayOfYear ou TimeSpans, car ils changent le nombre de jours des années bissextiles
  • J'y ai mis un peu plus de lignes pour plus de lisibilité

Encore une note ... Je créerais deux méthodes statiques surchargées, une pour l’utilisation universelle, la deuxième pour la convivialité:

public static int GetAge(DateTime bithDay, DateTime today) 
{ 
  //chosen solution method body
}

public static int GetAge(DateTime birthDay) 
{ 
  return GetAge(birthDay, DateTime.Now);
}

C'est une façon étrange de le faire, mais si vous formatez la date en yyyymmdd et soustrayez la date de naissance de la date actuelle, supprimez les 4 derniers chiffres de votre âge :)

Je ne sais pas C #, mais je pense que cela fonctionnera dans n'importe quelle langue.

20080814 - 19800703 = 280111 

Supprimer les 4 derniers chiffres = 28 .

Code C #:

int now = int.Parse(DateTime.Now.ToString("yyyyMMdd"));
int dob = int.Parse(dateOfBirth.ToString("yyyyMMdd"));
int age = (now - dob) / 10000;

Ou bien sans toute la conversion de type sous la forme d'une méthode d'extension. Erreur lors de la vérification omise:

public static Int32 GetAge(this DateTime dateOfBirth)
{
    var today = DateTime.Today;

    var a = (today.Year * 100 + today.Month) * 100 + today.Day;
    var b = (dateOfBirth.Year * 100 + dateOfBirth.Month) * 100 + dateOfBirth.Day;

    return (a - b) / 10000;
}

Ceci est la version que nous utilisons ici. Cela fonctionne et c'est assez simple. C'est la même idée que celle de Jeff, mais je pense que c'est un peu plus clair parce que cela sépare la logique de soustraction, donc c'est un peu plus facile à comprendre.

public static int GetAge(this DateTime dateOfBirth, DateTime dateAsAt)
{
    return dateAsAt.Year - dateOfBirth.Year - (dateOfBirth.DayOfYear < dateAsAt.DayOfYear ? 0 : 1);
}

Vous pouvez développer l'opérateur ternaire pour le rendre encore plus clair, si vous pensez que ce genre de chose n'est pas clair.

Évidemment, ceci est fait comme une méthode d'extension sur DateTime , mais vous pouvez évidemment saisir cette ligne de code qui fait le travail et le met n'importe où. Nous avons ici une autre surcharge de la méthode Extension qui passe dans DateTime.Now , juste pour être complet.


J'ai créé une fonction définie par l'utilisateur SQL Server pour calculer l'âge de quelqu'un, en fonction de sa date de naissance. Ceci est utile lorsque vous en avez besoin dans le cadre d'une requête:

using System;
using System.Data;
using System.Data.Sql;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;

public partial class UserDefinedFunctions
{
    [SqlFunction(DataAccess = DataAccessKind.Read)]
    public static SqlInt32 CalculateAge(string strBirthDate)
    {
        DateTime dtBirthDate = new DateTime();
        dtBirthDate = Convert.ToDateTime(strBirthDate);
        DateTime dtToday = DateTime.Now;

        // get the difference in years
        int years = dtToday.Year - dtBirthDate.Year;

        // subtract another year if we're before the
        // birth day in the current year
        if (dtToday.Month < dtBirthDate.Month || (dtToday.Month == dtBirthDate.Month && dtToday.Day < dtBirthDate.Day))
            years=years-1;

        int intCustomerAge = years;
        return intCustomerAge;
    }
};

J'ai passé quelque temps à travailler là-dessus et je l'ai imaginé pour calculer l'âge de quelqu'un en années, en mois et en jours. J'ai testé contre le problème du 29 février et les années bissextiles et cela semble fonctionner, je vous serais reconnaissant de vos commentaires:

public void LoopAge(DateTime myDOB, DateTime FutureDate)
{
    int years = 0;
    int months = 0;
    int days = 0;

    DateTime tmpMyDOB = new DateTime(myDOB.Year, myDOB.Month, 1);

    DateTime tmpFutureDate = new DateTime(FutureDate.Year, FutureDate.Month, 1);

    while (tmpMyDOB.AddYears(years).AddMonths(months) < tmpFutureDate)
    {
        months++;

        if (months > 12)
        {
            years++;
            months = months - 12;
        }
    }

    if (FutureDate.Day >= myDOB.Day)
    {
        days = days + FutureDate.Day - myDOB.Day;
    }
    else
    {
        months--;

        if (months < 0)
        {
            years--;
            months = months + 12;
        }

        days +=
            DateTime.DaysInMonth(
                FutureDate.AddMonths(-1).Year, FutureDate.AddMonths(-1).Month
            ) + FutureDate.Day - myDOB.Day;

    }

    //add an extra day if the dob is a leap day
    if (DateTime.IsLeapYear(myDOB.Year) && myDOB.Month == 2 && myDOB.Day == 29)
    {
        //but only if the future date is less than 1st March
        if (FutureDate >= new DateTime(FutureDate.Year, 3, 1))
            days++;
    }

}

Je ne sais pas comment une mauvaise solution peut être acceptée. Le bon extrait C # a été écrit par Michael Stum

Voici un extrait de test:

DateTime bDay = new DateTime(2000, 2, 29);
DateTime now = new DateTime(2009, 2, 28);
MessageBox.Show(string.Format("Test {0} {1} {2}",
                CalculateAgeWrong1(bDay, now),      // outputs 9
                CalculateAgeWrong2(bDay, now),      // outputs 9
                CalculateAgeCorrect(bDay, now),     // outputs 8
                CalculateAgeCorrect2(bDay, now)));  // outputs 8

Ici vous avez les méthodes:

public int CalculateAgeWrong1(DateTime birthDate, DateTime now)
{
    return new DateTime(now.Subtract(birthDate).Ticks).Year - 1;
}

public int CalculateAgeWrong2(DateTime birthDate, DateTime now)
{
    int age = now.Year - birthDate.Year;

    if (now < birthDate.AddYears(age))
        age--;

    return age;
}

public int CalculateAgeCorrect(DateTime birthDate, DateTime now)
{
    int age = now.Year - birthDate.Year;

    if (now.Month < birthDate.Month || (now.Month == birthDate.Month && now.Day < birthDate.Day))
        age--;

    return age;
}

public int CalculateAgeCorrect2(DateTime birthDate, DateTime now)
{
    int age = now.Year - birthDate.Year;

    // for leap years we need this
    if (birthDate > now.AddYears(-age)) age--;
    // don't use:
    // if (birthDate.AddYears(age) > now) age--;

    return age;
}

Je suis en retard à la fête, mais voici un one-liner:

int age = new DateTime(DateTime.Now.Subtract(birthday).Ticks).Year-1;

La réponse simple à cette question est d’appliquer AddYears comme indiqué ci-dessous car c’est la seule méthode native pour ajouter des années au 29 février des années bissextiles et obtenir le résultat correct du 28 février pour les années ordinaires.

Certains pensent que le 1er mars est la date anniversaire des cultures, mais ni Net ni aucune règle officielle ne le corroborent, et la logique ne permet pas non plus d'expliquer pourquoi certains nés en février devraient avoir 75% de leur anniversaire dans un mois.

De plus, une méthode Age se prête à être ajoutée en tant qu'extension à DateTime . En cela, vous pouvez obtenir l'âge de la manière la plus simple possible:

  1. Élément de liste

int age = birthDate.Age ();

public static class DateTimeExtensions
{
    /// <summary>
    /// Calculates the age in years of the current System.DateTime object today.
    /// </summary>
    /// <param name="birthDate">The date of birth</param>
    /// <returns>Age in years today. 0 is returned for a future date of birth.</returns>
    public static int Age(this DateTime birthDate)
    {
        return Age(birthDate, DateTime.Today);
    }

    /// <summary>
    /// Calculates the age in years of the current System.DateTime object on a later date.
    /// </summary>
    /// <param name="birthDate">The date of birth</param>
    /// <param name="laterDate">The date on which to calculate the age.</param>
    /// <returns>Age in years on a later day. 0 is returned as minimum.</returns>
    public static int Age(this DateTime birthDate, DateTime laterDate)
    {
        int age;
        age = laterDate.Year - birthDate.Year;

        if (age > 0)
        {
            age -= Convert.ToInt32(laterDate.Date < birthDate.Date.AddYears(age));
        }
        else
        {
            age = 0;
        }

        return age;
    }
}

Maintenant, lancez ce test:

class Program
{
    static void Main(string[] args)
    {
        RunTest();
    }

    private static void RunTest()
    {
        DateTime birthDate = new DateTime(2000, 2, 28);
        DateTime laterDate = new DateTime(2011, 2, 27);
        string iso = "yyyy-MM-dd";

        for (int i = 0; i < 3; i++)
        {
            for (int j = 0; j < 3; j++)
            {
                Console.WriteLine("Birth date: " + birthDate.AddDays(i).ToString(iso) + "  Later date: " + laterDate.AddDays(j).ToString(iso) + "  Age: " + birthDate.AddDays(i).Age(laterDate.AddDays(j)).ToString());
            }
        }

        Console.ReadKey();
    }
}

Voici un exemple de date critique:

Date de naissance: 2000-02-29 Date ultérieure: 2011-02-28 Age: 11

Sortie:

{
    Birth date: 2000-02-28  Later date: 2011-02-27  Age: 10
    Birth date: 2000-02-28  Later date: 2011-02-28  Age: 11
    Birth date: 2000-02-28  Later date: 2011-03-01  Age: 11
    Birth date: 2000-02-29  Later date: 2011-02-27  Age: 10
    Birth date: 2000-02-29  Later date: 2011-02-28  Age: 11
    Birth date: 2000-02-29  Later date: 2011-03-01  Age: 11
    Birth date: 2000-03-01  Later date: 2011-02-27  Age: 10
    Birth date: 2000-03-01  Later date: 2011-02-28  Age: 10
    Birth date: 2000-03-01  Later date: 2011-03-01  Age: 11
}

Et pour la date ultérieure 2012-02-28:

{
    Birth date: 2000-02-28  Later date: 2012-02-28  Age: 12
    Birth date: 2000-02-28  Later date: 2012-02-29  Age: 12
    Birth date: 2000-02-28  Later date: 2012-03-01  Age: 12
    Birth date: 2000-02-29  Later date: 2012-02-28  Age: 11
    Birth date: 2000-02-29  Later date: 2012-02-29  Age: 12
    Birth date: 2000-02-29  Later date: 2012-03-01  Age: 12
    Birth date: 2000-03-01  Later date: 2012-02-28  Age: 11
    Birth date: 2000-03-01  Later date: 2012-02-29  Age: 11
    Birth date: 2000-03-01  Later date: 2012-03-01  Age: 12
}

Le meilleur moyen que je connaisse à cause des années bissextiles et de tout est:

DateTime birthDate = new DateTime(2000,3,1);
int age = (int)Math.Floor((DateTime.Now - birthDate).TotalDays / 365.25D);

J'espère que cela t'aides.


Rester simple (et éventuellement stupide :)).

DateTime birth = new DateTime(1975, 09, 27, 01, 00, 00, 00);
TimeSpan ts = DateTime.Now - birth;
Console.WriteLine("You are approximately " + ts.TotalSeconds.ToString() + " seconds old.");

Une autre fonction, pas par moi mais trouvée sur le web et affinée un peu:

public static int GetAge(DateTime birthDate)
{
    DateTime n = DateTime.Now; // To avoid a race condition around midnight
    int age = n.Year - birthDate.Year;

    if (n.Month < birthDate.Month || (n.Month == birthDate.Month && n.Day < birthDate.Day))
        age--;

    return age;
}

Deux choses me viennent à l’esprit: qu’en est-il des personnes de pays qui n’utilisent pas le calendrier grégorien? DateTime.Now est dans la culture spécifique du serveur, je pense. Je ne connais absolument aucun moyen de travailler avec des calendriers asiatiques et je ne sais pas s'il existe un moyen facile de convertir des dates entre les calendriers, mais juste au cas où vous vous interrogeriez sur ces Chinois de l'année 4660 :-)


Voici encore une autre réponse:

public static int AgeInYears(DateTime birthday, DateTime today)
{
    return ((today.Year - birthday.Year) * 372 + (today.Month - birthday.Month) * 31 + (today.Day - birthday.Day)) / 372;
}

Cela a été minutieusement testé. Ça a l'air un peu "magique". Le nombre 372 est le nombre de jours qu'il y aurait dans une année si chaque mois comptait 31 jours.

L'explication de pourquoi cela fonctionne ( levé d'ici ) est:

Définissons Yn = DateTime.Now.Year, Yb = birthday.Year, Mn = DateTime.Now.Month, Mb = birthday.Month, Dn = DateTime.Now.Day, Db = birthday.Day

age = Yn - Yb + (31*(Mn - Mb) + (Dn - Db)) / 372

Nous savons que nous avons besoin de Yn-Yb si la date a déjà été atteinte, Yn-Yb-1 si elle ne l’a pas encore été.

a) Si Mn<Mb , nous avons -341 <= 31*(Mn-Mb) <= -31 and -30 <= Dn-Db <= 30

-371 <= 31*(Mn - Mb) + (Dn - Db) <= -1

Avec division entière

(31*(Mn - Mb) + (Dn - Db)) / 372 = -1

b) Si Mn=Mb et Dn<Db , nous avons 31*(Mn - Mb) = 0 and -30 <= Dn-Db <= -1

Avec division entière, encore

(31*(Mn - Mb) + (Dn - Db)) / 372 = -1

c) Si Mn>Mb , nous avons 31 <= 31*(Mn-Mb) <= 341 and -30 <= Dn-Db <= 30

1 <= 31*(Mn - Mb) + (Dn - Db) <= 371

Avec division entière

(31*(Mn - Mb) + (Dn - Db)) / 372 = 0

d) Si Mn=Mb et Dn>Db , nous avons 31*(Mn - Mb) = 0 and 1 <= Dn-Db <= 3 0

Avec division entière, encore

(31*(Mn - Mb) + (Dn - Db)) / 372 = 0

e) Si Mn=Mb et Dn=Db , nous avons 31*(Mn - Mb) + Dn-Db = 0

et donc (31*(Mn - Mb) + (Dn - Db)) / 372 = 0


private int GetAge(int _year, int _month, int _day
{
    DateTime yourBirthDate= new DateTime(_year, _month, _day);

    DateTime todaysDateTime = DateTime.Today;
    int noOfYears = todaysDateTime.Year - yourBirthDate.Year;

    if (DateTime.Now.Month < yourBirthDate.Month ||
        (DateTime.Now.Month == yourBirthDate.Month && DateTime.Now.Day < yourBirthDate.Day))
    {
        noOfYears--;
    }

    return  noOfYears;
}






datetime