Hogyan számolom valaki kor a C #?

szavazat
1k

Adott egy DateTimeképviselő személy születésnapját, hogyan számolják ki az életkor években?

A kérdést 01/08/2008 00:40
a forrás felhasználó
Más nyelveken...                            


64 válasz

szavazat
1k

Egy könnyen érthető és egyszerű megoldás.

// Save today's date.
var today = DateTime.Today;
// Calculate the age.
var age = today.Year - birthdate.Year;
// Go back to the year the person was born in case of a leap year
if (birthdate > today.AddYears(-age)) age--;

Azonban ez azt feltételezi, amit keres a nyugati ötlet kor és nem használja a kelet-ázsiai számvetés .

Válaszolt 04/08/2008 17:50
a forrás felhasználó

szavazat
874

Ez egy furcsa módon kell csinálni, de ha formázza a dátumot yyyymmddés vonjuk ki a születési dátum az aktuális dátumot, majd dobja az utolsó 4 számjegy megvan a kor :)

Nem tudom, hogy a C #, de úgy vélem, hogy ez működni fog bármilyen nyelven.

20080814 - 19800703 = 280111 

Dobd az utolsó 4 számjegy = 28.

C # kód:

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

Vagy pedig nem az összes típusú átalakítás formájában kiterjesztése módszer. Hibaellenőrző elhagyható:

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;
}
Válaszolt 15/08/2008 04:47
a forrás felhasználó

szavazat
336

Nem tudom, hogy a rossz megoldás fogadható el. A megfelelő C # kódrészletet írta Michael Stum

Itt van egy teszt a következő részletet:

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

Itt van mód:

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;
}
Válaszolt 20/10/2009 16:07
a forrás felhasználó

szavazat
113

Nem hiszem, hogy bármely a választ eddig biztosítani kultúrák számítani kor másképp. Lásd például a kelet-ázsiai Age Reckoning szemben, hogy a Nyugat.

Bármilyen valós választ kell tartalmaznia lokalizáció. A stratégia minta valószínűleg annak érdekében, ebben a példában.

Válaszolt 17/08/2008 18:14
a forrás felhasználó

szavazat
98

Az egyszerű válasz erre az, hogy alkalmazni AddYearsaz alábbiak szerint azért, mert ez az egyetlen őshonos módszer évekkel a február 29 Szökőévek és megszerezni a megfelelő eredményt a február 28 közös év.

Néhányan úgy érzik, hogy március 1 a születésnapja leaplings de sem Net sem hivatalos szabály támogatja ezt, és nem közös logika magyarázza, miért néhány februárjában született meg már 75% -át a születésnapokat egy hónap.

Továbbá egy Age módszer alkalmas arra, hogy ki, mint egy kiterjesztése DateTime. Ezzel meg tudja szerezni az életkor, a lehető legegyszerűbb módon:

  1. Listaelem

int kor = 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;
    }
}

Most futtatni ezt a tesztet:

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();
    }
}

A kritikus dátum például ez:

Születési dátum: 2000/02/29 Később dátuma: 2011-02-28 Age: 11

output:

{
    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
}

És a későbbi időpontban 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
}
Válaszolt 20/02/2011 00:56
a forrás felhasználó

szavazat
74

Az én javaslatom

int age = (int) ((DateTime.Now - bday).TotalDays/365.242199);

Úgy tűnik, hogy az év változó a jobb időpontban. (I pontszerűen tesztelt éves korig 107)

Válaszolt 03/10/2008 21:19
a forrás felhasználó

szavazat
61

Egy másik funkció, nem én, hanem megtalálható az interneten, és kifinomult, hogy egy kicsit:

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;
}

Csak két dolog jutott eszembe: Mi a helyzet az emberek országok, amelyek nem használják a Gergely-naptár? DateTime.Now van a szerver-specifikus kultúra azt hiszem. Egyáltalán 0 ismereteket ténylegesen dolgozó ázsiai naptárak és nem tudom, hogy van egy egyszerű módja annak, hogy konvertálni dátumokat között naptárak, de csak abban az esetben, ha kíváncsiak azokról kínai srácok az év 4660 :-)

Válaszolt 01/08/2008 22:46
a forrás felhasználó

szavazat
43

2 Fő problémák megoldására a következők:

1. Számítsuk koráról - az év, hónap, nap, stb

2. Számítsuk Általában érzékelt életkor - az emberek általában nem érdekli, hány évesek is pontosan, csak érdekel, amikor a születésnapját tárgyévben.


Megoldás 1 nyilvánvaló:

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

Megoldás 2 az egyetlen, amely nem olyan pontos a meghatározó elemeivel teljes kor, de érzékeljük pontosan az emberek. Az emberek is általában használni, amikor kiszámítja a koruk „kézzel”:

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
}

Jegyzetek 2 .:

  • Ez az én preferált megoldás
  • Nem tudjuk használni DateTime.DayOfYear vagy TimeSpans, ahogy váltani napok száma szökőévekben
  • Tettem ott kicsit több sor olvashatóság

Csak még egy megjegyzés ... én okozna 2 statikus túlterhelt módszereket is, egy univerzális használat, második a használat-barát:

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

public static int GetAge(DateTime birthDay) 
{ 
  return GetAge(birthDay, DateTime.Now);
}
Válaszolt 11/04/2011 15:47
a forrás felhasználó

szavazat
42

Én végén a párt, de itt van egy egysoros:

int age = new DateTime(DateTime.Now.Subtract(birthday).Ticks).Year-1;
Válaszolt 18/05/2009 13:36
a forrás felhasználó

szavazat
32

Ezt a változatot fogjuk használni. Úgy működik, és ez meglehetősen egyszerű. Ez ugyanaz a gondolat, mint Jeff, de azt hiszem, ez egy kicsit világosabb, mert szétválasztja a logika egyet kivonva, így ez egy kicsit könnyebb megérteni.

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

Lehet bővíteni a háromkomponensű üzemeltetője, hogy még világosabb, ha úgy gondolja, hogy az ilyesmit nem tisztázott.

Nyilvánvaló, hogy ez történik, mint egy kiterjesztése módszer DateTime, de nyilvánvalóan akkor megragad, hogy egy sor kód, amely elvégzi a munkát, és tegye sehova. Itt van egy másik túlterhelése Extension módszer, amely átmegy DateTime.Now, csak a teljesség kedvéért.

Válaszolt 06/08/2008 11:23
a forrás felhasználó

szavazat
31

Sok évvel ezelőtt, hogy olyan korban számológép trükk a honlapomon, írtam egy függvényt számítani kor töredékére. Ez egy gyors kikötő ezt a funkciót a C # (az a PHP verzió ). Félek nem tudták, hogy teszteljék a C # verzió, de remélem, tetszeni mindegy!

(Igaz ez egy kicsit hatásvadász céljából mutató felhasználói profilok Veremtúlcsordulás, de talán az olvasók megtalálják néhány hasznát. :-))

double AgeDiff(DateTime date1, DateTime date2) {
    double years = date2.Year - date1.Year;

    /*
     * If date2 and date1 + round(date2 - date1) are on different sides
     * of 29 February, then our partial year is considered to have 366
     * days total, otherwise it's 365. Note that 59 is the day number
     * of 29 Feb.
     */
    double fraction = 365
            + (DateTime.IsLeapYear(date2.Year) && date2.DayOfYear >= 59
            && (date1.DayOfYear < 59 || date1.DayOfYear > date2.DayOfYear)
            ? 1 : 0);

    /*
     * The only really nontrivial case is if date1 is in a leap year,
     * and date2 is not. So let's handle the others first.
     */
    if (DateTime.IsLeapYear(date2.Year) == DateTime.IsLeapYear(date1.Year))
        return years + (date2.DayOfYear - date1.DayOfYear) / fraction;

    /*
     * If date2 is in a leap year, but date1 is not and is March or
     * beyond, shift up by a day.
     */
    if (DateTime.IsLeapYear(date2.Year)) {
        return years + (date2.DayOfYear - date1.DayOfYear
                - (date1.DayOfYear >= 59 ? 1 : 0)) / fraction;
    }

    /*
     * If date1 is not on 29 February, shift down date1 by a day if
     * March or later. Proceed normally.
     */
    if (date1.DayOfYear != 59) {
        return years + (date2.DayOfYear - date1.DayOfYear
                + (date1.DayOfYear > 59 ? 1 : 0)) / fraction;
    }

    /*
     * Okay, here date1 is on 29 February, and date2 is not on a leap
     * year. What to do now? On 28 Feb in date2's year, the ``age''
     * should be just shy of a whole number, and on 1 Mar should be
     * just over. Perhaps the easiest way is to a point halfway
     * between those two: 58.5.
     */
    return years + (date2.DayOfYear - 58.5) / fraction;
}
Válaszolt 01/08/2008 09:57
a forrás felhasználó

szavazat
29

Én ezt:

public static class DateTimeExtensions
{
    public static int Age(this DateTime birthDate)
    {
        return Age(birthDate, DateTime.Now);
    }

    public static int Age(this DateTime birthDate, DateTime offsetDate)
    {
        int result=0;
        result = offsetDate.Year - birthDate.Year;

        if (offsetDate.DayOfYear < birthDate.DayOfYear)
        {
              result--;
        }

        return result;
    }
}
Válaszolt 17/02/2010 14:32
a forrás felhasználó

szavazat
26

Ez ad „részletesen”, hogy erre a kérdésre. Talán ez az, amit keres

DateTime birth = new DateTime(1974, 8, 29);
DateTime today = DateTime.Now;
TimeSpan span = today - birth;
DateTime age = DateTime.MinValue + span;

// Make adjustment due to MinValue equalling 1/1/1
int years = age.Year - 1;
int months = age.Month - 1;
int days = age.Day - 1;

// Print out not only how many years old they are but give months and days as well
Console.Write("{0} years, {1} months, {2} days", years, months, days);
Válaszolt 20/09/2013 20:13
a forrás felhasználó

szavazat
26

A legjobb módja annak, hogy tudom, mert Szökőévek és minden:

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

Remélem ez segít.

Válaszolt 01/08/2008 13:07
a forrás felhasználó

szavazat
22

Létrehoztam egy SQL Server felhasználó által definiált függvényt kiszámításához valaki életkora, mivel azok születési dátum. Ez akkor hasznos, ha szükség van rá részeként a lekérdezés:

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;
    }
};
Válaszolt 23/08/2008 14:58
a forrás felhasználó

szavazat
21

Már egy ideig dolgozik ezen, és jött ez a kiszámításához valaki életkora évben, hónapban és napon. Kipróbáltam ellen február 29 problémát és Szökőévek és úgy tűnik, működik, örülnék minden visszajelzést:

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++;
    }

}
Válaszolt 18/05/2009 12:24
a forrás felhasználó

szavazat
16

Ne figyelembe kell vennünk, akik kisebb, mint 1 év? a kínai kultúra, leírjuk a kis csecsemő korban 2 hónapos vagy 4 hét.

Az alábbiakban az én végrehajtás, ez nem olyan egyszerű, mint amit elképzeltem, különösen foglalkozni dátum, mint 2/28.

public static string HowOld(DateTime birthday, DateTime now)
{
    if (now < birthday)
        throw new ArgumentOutOfRangeException("birthday must be less than now.");

    TimeSpan diff = now - birthday;
    int diffDays = (int)diff.TotalDays;

    if (diffDays > 7)//year, month and week
    {
        int age = now.Year - birthday.Year;

        if (birthday > now.AddYears(-age))
            age--;

        if (age > 0)
        {
            return age + (age > 1 ? " years" : " year");
        }
        else
        {// month and week
            DateTime d = birthday;
            int diffMonth = 1;

            while (d.AddMonths(diffMonth) <= now)
            {
                diffMonth++;
            }

            age = diffMonth-1;

            if (age == 1 && d.Day > now.Day)
                age--;

            if (age > 0)
            {
                return age + (age > 1 ? " months" : " month");
            }
            else
            {
                age = diffDays / 7;
                return age + (age > 1 ? " weeks" : " week");
            }
        }
    }
    else if (diffDays > 0)
    {
        int age = diffDays;
        return age + (age > 1 ? " days" : " day");
    }
    else
    {
        int age = diffDays;
        return "just born";
    }
}

Ez a végrehajtási telt alábbi teszt esetek.

[TestMethod]
public void TestAge()
{
    string age = HowOld(new DateTime(2011, 1, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("1 year", age);

    age = HowOld(new DateTime(2011, 11, 30), new DateTime(2012, 11, 30));
    Assert.AreEqual("1 year", age);

    age = HowOld(new DateTime(2001, 1, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("11 years", age);

    age = HowOld(new DateTime(2012, 1, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("10 months", age);

    age = HowOld(new DateTime(2011, 12, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("11 months", age);

    age = HowOld(new DateTime(2012, 10, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("1 month", age);

    age = HowOld(new DateTime(2008, 2, 28), new DateTime(2009, 2, 28));
    Assert.AreEqual("1 year", age);

    age = HowOld(new DateTime(2008, 3, 28), new DateTime(2009, 2, 28));
    Assert.AreEqual("11 months", age);

    age = HowOld(new DateTime(2008, 3, 28), new DateTime(2009, 3, 28));
    Assert.AreEqual("1 year", age);

    age = HowOld(new DateTime(2009, 1, 28), new DateTime(2009, 2, 28));
    Assert.AreEqual("1 month", age);

    age = HowOld(new DateTime(2009, 2, 1), new DateTime(2009, 3, 1));
    Assert.AreEqual("1 month", age);

    // NOTE.
    // new DateTime(2008, 1, 31).AddMonths(1) == new DateTime(2009, 2, 28);
    // new DateTime(2008, 1, 28).AddMonths(1) == new DateTime(2009, 2, 28);
    age = HowOld(new DateTime(2009, 1, 31), new DateTime(2009, 2, 28));
    Assert.AreEqual("4 weeks", age);

    age = HowOld(new DateTime(2009, 2, 1), new DateTime(2009, 2, 28));
    Assert.AreEqual("3 weeks", age);

    age = HowOld(new DateTime(2009, 2, 1), new DateTime(2009, 3, 1));
    Assert.AreEqual("1 month", age);

    age = HowOld(new DateTime(2012, 11, 5), new DateTime(2012, 11, 30));
    Assert.AreEqual("3 weeks", age);

    age = HowOld(new DateTime(2012, 11, 1), new DateTime(2012, 11, 30));
    Assert.AreEqual("4 weeks", age);

    age = HowOld(new DateTime(2012, 11, 20), new DateTime(2012, 11, 30));
    Assert.AreEqual("1 week", age);

    age = HowOld(new DateTime(2012, 11, 25), new DateTime(2012, 11, 30));
    Assert.AreEqual("5 days", age);

    age = HowOld(new DateTime(2012, 11, 29), new DateTime(2012, 11, 30));
    Assert.AreEqual("1 day", age);

    age = HowOld(new DateTime(2012, 11, 30), new DateTime(2012, 11, 30));
    Assert.AreEqual("just born", age);

    age = HowOld(new DateTime(2000, 2, 29), new DateTime(2009, 2, 28));
    Assert.AreEqual("8 years", age);

    age = HowOld(new DateTime(2000, 2, 29), new DateTime(2009, 3, 1));
    Assert.AreEqual("9 years", age);

    Exception e = null;

    try
    {
        age = HowOld(new DateTime(2012, 12, 1), new DateTime(2012, 11, 30));
    }
    catch (ArgumentOutOfRangeException ex)
    {
        e = ex;
    }

    Assert.IsTrue(e != null);
}

Remélem ez segít.

Válaszolt 30/11/2012 13:13
a forrás felhasználó

szavazat
15
TimeSpan diff = DateTime.Now - birthdayDateTime;
string age = String.Format("{0:%y} years, {0:%M} months, {0:%d}, days old", diff);

Nem vagyok benne biztos, hogy pontosan azt szeretné, hogy vissza Önnek, úgyhogy csak tett egy olvasható szöveg.

Válaszolt 19/09/2013 16:18
a forrás felhasználó

szavazat
15

A legegyszerűbb módja annak, amit valaha találtam ezt. Úgy működik rendesen az Egyesült Államokban és Nyugat-Európában helyszíneken. Nem tud más helyszíneken, különösen olyan helyeken, mint Kínában. 4 extra le, legfeljebb a kezdeti számítás korig.

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 ;
}

Kerestem át a választ erre, és észrevette, hogy senki nem tett utalást a szabályozási / jogi következményeit szökõnaphatástól szülés. Például egy Wikipedia , ha született február 29 különböző joghatóságok, te nem szökőév születésnapját változik:

  • Az Egyesült Királyságban és Hong Kong: ez a sorrendi nap az évben, így a következő napon, március 1 van a születésnapja.
  • Új-Zéland: ez az előző napon, február 28 céljára vezető engedélyezési és március 1 egyéb célokra.
  • Tajvan: a február 28-án.

És minél közelebb tudok mondani, az USA-ban, az alapszabály hallgat az ügyben, így azt akár a common law és hogy a különböző szabályozó testületek határozzák meg a dolgokat a saját előírásoknak.

E célból, javulást:

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;
}

Meg kell jegyezni, hogy ez a kód feltételezi:

  • A nyugati (európai) kiszámítása kor, és
  • A naptár, mint a Gergely-naptár, amely beilleszti egyetlen ugrással nap végén egy hónap alatt.
Válaszolt 06/10/2010 02:49
a forrás felhasználó

szavazat
15

Tartása egyszerű (és esetleg hülye :)).

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.");
Válaszolt 18/08/2010 15:29
a forrás felhasználó

szavazat
14

Ez az egyik legpontosabb választ, amely képes megoldani a születésnapját február 29 összehasonlítani bármelyik évében február 28

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

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

    return age;
}
Válaszolt 23/10/2014 14:18
a forrás felhasználó

szavazat
13

Itt van még egy válasz:

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

Ez már alaposan egységet tesztelt. Úgy néz ki egy kicsit „mágikus”. A szám 372 a napok száma nem lenne egy évben, ha minden hónapban volt 31 napot.

A magyarázat, hogy miért működik ( felemelhető itt is):

Állítsunk 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

Tudjuk, hogy mire van szükségünk, az vagy Yn-Yb, ha a dátum már elérték, Yn-Yb-1ha nem.

a) Ha Mn<Mb, van-341 <= 31*(Mn-Mb) <= -31 and -30 <= Dn-Db <= 30

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

Az osztás

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

b) Ha Mn=Mbés Dn<Db, van31*(Mn - Mb) = 0 and -30 <= Dn-Db <= -1

A osztás, újra

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

c) Ha Mn>Mb, van31 <= 31*(Mn-Mb) <= 341 and -30 <= Dn-Db <= 30

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

Az osztás

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

d) Ha Mn=Mbés Dn>Db, van 31*(Mn - Mb) = 0 and 1 <= Dn-Db <= 30

A osztás, újra

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

e) Ha Mn=Mbés Dn=Db, van31*(Mn - Mb) + Dn-Db = 0

és ezért (31*(Mn - Mb) + (Dn - Db)) / 372 = 0

Válaszolt 22/04/2013 09:19
a forrás felhasználó

szavazat
13

Ez nem közvetlen választ, hanem inkább egy filozófiai érvelés a szóban forgó problémára egy kvázi-tudományos szempontból.

Azt állítják, hogy a kérdés nem adjuk meg az egység, sem a kultúra, amellyel mérhető az életkor, a legtöbb válasz úgy tűnik, hogy vállalja egy egész éves képviselete. Az SI-egység idő second, ergo a helyes generikus választ kellene adni (természetesen feltételezve normalizált DateTimeés figyelembe nem véve egyáltalán, hogy a relativisztikus hatások):

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

A keresztény számításának módját életkor években:

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

Pénzügy van egy hasonló probléma kiszámításakor valami gyakran nevezik a Kamatbázis , ami nagyjából egy több évig egy adott időszakban. És a kor kérdése valóban időmérő kérdés.

Példa a tényleges / tényleges (számítva minden nap „helyes”) Egyezmény:

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;

Egy másik, szintén gyakori módja, hogy idő méréséhez általában a „szerializációja” (a fickó, aki elemzi az ezen időpont egyezmény kell komolyan lehetett trippin'):

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

Kíváncsi vagyok, meddig kell mennünk, mielőtt a relativisztikus kor másodpercben sokkal hasznosabb, mint a durva közelítéssel föld körül-sun-ciklusok során az ember élettartama eddig :) Vagy más szóval, ha egy ideig meg kell adni a helyet, vagy függvényében ábrázoló irányuló önmagában is érvényes :)

Válaszolt 23/11/2012 16:00
a forrás felhasználó

szavazat
13

Itt van egy megoldás.

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);
Válaszolt 18/06/2009 11:35
a forrás felhasználó

szavazat
12

Hogy ebben a megoldásban?

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"; ;
}
Válaszolt 08/03/2011 08:25
a forrás felhasználó

szavazat
11

Van egy egyedi módszert kiszámításához az életkor, valamint egy bónusz érvényesítés üzenet csak abban az esetben segít:

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
}

Metódushívás itt és elájul datetime érték (MM / dd / yyyy, ha a szerver beállítva, hogy USA locale). Cserélje ezt semmivel egy messagebox vagy bármely tartályt display:

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

Ne feledje, akkor formázza meg az üzenetet, ahogy neked tetszik.

Válaszolt 22/01/2014 08:23
a forrás felhasználó

szavazat
10
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;
}
Válaszolt 06/09/2010 15:09
a forrás felhasználó

szavazat
8

SQL verzió:

declare @dd smalldatetime = '1980-04-01'
declare @age int = YEAR(GETDATE())-YEAR(@dd)
if (@dd> DATEADD(YYYY, -@age, GETDATE())) set @age = @age -1

print @age  
Válaszolt 30/06/2016 11:24
a forrás felhasználó

szavazat
8

Régebben ScArcher2 megoldása az pontos éve számítását személyek életkora, de szükséges, hogy vigye tovább, és számítsuk ki Hónapok és napok együtt az évek során.

    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;
}
Válaszolt 12/08/2011 21:53
a forrás felhasználó

szavazat
6

Wow, én kellett adni a véleményét itt .. Annyi választ az ilyen egyszerű

private int CalcularIdade(DateTime dtNascimento)
    {
        var nHoje = Convert.ToInt32(DateTime.Today.ToString("yyyyMMdd"));
        var nAniversario = Convert.ToInt32(dtNascimento.ToString("yyyyMMdd"));

        double diff = (nHoje - nAniversario) / 10000;

        var ret = Convert.ToInt32(Math.Truncate(diff));

        return ret;
    }

Remélem ez segít valakinek, legalább tesz valaki úgy gondolja .. :)

Válaszolt 29/09/2016 20:13
a forrás felhasználó

szavazat
6

Ez a legegyszerűbb módja annak, hogy erre a kérdésre választ egy sort.

DateTime Dob = DateTime.Parse("1985-04-24");

int Age = DateTime.MinValue.AddDays(DateTime.Now.Subtract(Dob).TotalHours/24).Year - 1;

Ez is működik szökőév.

Válaszolt 27/04/2016 14:58
a forrás felhasználó

szavazat
6

A következő megközelítés (kivonat Időszak Library for .NET osztály DateDiff ) úgy véli, a naptár, a kultúra info:

// ----------------------------------------------------------------------
private static int YearDiff( DateTime date1, DateTime date2 )
{
  return YearDiff( date1, date2, DateTimeFormatInfo.CurrentInfo.Calendar );
} // YearDiff

// ----------------------------------------------------------------------
private static int YearDiff( DateTime date1, DateTime date2, Calendar calendar )
{
  if ( date1.Equals( date2 ) )
  {
    return 0;
  }

  int year1 = calendar.GetYear( date1 );
  int month1 = calendar.GetMonth( date1 );
  int year2 = calendar.GetYear( date2 );
  int month2 = calendar.GetMonth( date2 );

  // find the the day to compare
  int compareDay = date2.Day;
  int compareDaysPerMonth = calendar.GetDaysInMonth( year1, month1 );
  if ( compareDay > compareDaysPerMonth )
  {
    compareDay = compareDaysPerMonth;
  }

  // build the compare date
  DateTime compareDate = new DateTime( year1, month2, compareDay,
    date2.Hour, date2.Minute, date2.Second, date2.Millisecond );
  if ( date2 > date1 )
  {
    if ( compareDate < date1 )
    {
      compareDate = compareDate.AddYears( 1 );
    }
  }
  else
  {
    if ( compareDate > date1 )
    {
      compareDate = compareDate.AddYears( -1 );
    }
  }
  return year2 - calendar.GetYear( compareDate );
} // YearDiff

Használat:

// ----------------------------------------------------------------------
public void CalculateAgeSamples()
{
  PrintAge( new DateTime( 2000, 02, 29 ), new DateTime( 2009, 02, 28 ) );
  // > Birthdate=29.02.2000, Age at 28.02.2009 is 8 years
  PrintAge( new DateTime( 2000, 02, 29 ), new DateTime( 2012, 02, 28 ) );
  // > Birthdate=29.02.2000, Age at 28.02.2012 is 11 years
} // CalculateAgeSamples

// ----------------------------------------------------------------------
public void PrintAge( DateTime birthDate, DateTime moment )
{
  Console.WriteLine( "Birthdate={0:d}, Age at {1:d} is {2} years", birthDate, moment, YearDiff( birthDate, moment ) );
} // PrintAge
Válaszolt 13/05/2011 09:12
a forrás felhasználó

szavazat
5
    private int GetYearDiff(DateTime start, DateTime end)
    {
        int diff = end.Year - start.Year;
        if (end.DayOfYear < start.DayOfYear) { diff -= 1; }
        return diff;
    }
    [Fact]
    public void GetYearDiff_WhenCalls_ShouldReturnCorrectYearDiff()
    {
        //arrange
        var now = DateTime.Now;
        //act
        //assert
        Assert.Equal(24, GetYearDiff(new DateTime(1992, 7, 9), now)); // passed
        Assert.Equal(24, GetYearDiff(new DateTime(1992, now.Month, now.Day), now)); // passed
        Assert.Equal(23, GetYearDiff(new DateTime(1992, 12, 9), now)); // passed
    }
Válaszolt 22/10/2016 19:10
a forrás felhasználó

szavazat
5

=== mondás (hónapoktól éves) ===

Ha csak közös használatra, itt a kód, mint az adatok:

DateTime today = DateTime.Today;
DateTime bday = DateTime.Parse("2016-2-14");
int age = today.Year - bday.Year;
var unit = "";

if (bday > today.AddYears(-age))
{
    age--;
}
if (age == 0)   // Under one year old
{
    age = today.Month - bday.Month;

    age = age <= 0 ? (12 + age) : age;  // The next year before birthday

    age = today.Day - bday.Day >= 0 ? age : --age;  // Before the birthday.day

    unit = "month";
}
else {
    unit = "year";
}

if (age > 1)
{
    unit = unit + "s";
}

A teszt eredménye az alábbiak szerint:

The birthday: 2016-2-14

2016-2-15 =>  age=0, unit=month;
2016-5-13 =>  age=2, unit=months;
2016-5-14 =>  age=3, unit=months; 
2016-6-13 =>  age=3, unit=months; 
2016-6-15 =>  age=4, unit=months; 
2017-1-13 =>  age=10, unit=months; 
2017-1-14 =>  age=11, unit=months; 
2017-2-13 =>  age=11, unit=months; 
2017-2-14 =>  age=1, unit=year; 
2017-2-15 =>  age=1, unit=year; 
2017-3-13 =>  age=1, unit=year;
2018-1-13 =>  age=1, unit=year; 
2018-1-14 =>  age=1, unit=year; 
2018-2-13 =>  age=1, unit=year; 
2018-2-14 =>  age=2, unit=years; 
Válaszolt 04/05/2016 08:29
a forrás felhasználó

szavazat
5

Ez egyszerű, és úgy tűnik, hogy azok pontosak a saját igényeinek. Én így feltételezés céljából Szökőévek hogy függetlenül attól, amikor az ember úgy dönt, hogy megünnepeljék a születésnapját ők technikailag nem egy évvel idősebb, míg egy teljes 365 nap telt el azóta, ott a legutóbbi születésnapjára (azaz február 28. nem teszi őket egy éve idősebb)

DateTime now = DateTime.Today;
DateTime birthday = new DateTime(1991, 02, 03);//3rd feb

int age = now.Year - birthday.Year;

if (now.Month < birthday.Month || (now.Month == birthday.Month && now.Day < birthday.Day))//not had bday this year yet
  age--;

return age;

Tudassa velünk, ha problémákat lát;)

Válaszolt 24/02/2012 13:58
a forrás felhasználó

szavazat
4

Csináltam egy kis változás, hogy Mark SOEN a válasz: Már rewriten a harmadik sorban úgy, hogy a kifejezés értelmezhető egy kicsit könnyebben.

public int AgeInYears(DateTime bday)
{
    DateTime now = DateTime.Today;
    int age = now.Year - bday.Year;            
    if (bday.AddYears(age) > now) 
        age--;
    return age;
}

Én is tette egy funkciót az egyértelműség kedvéért.

Válaszolt 16/07/2011 19:01
a forrás felhasználó

szavazat
3
public string GetAge(this DateTime birthdate, string ageStrinFormat = null)
{
    var date = DateTime.Now.AddMonths(-birthdate.Month).AddDays(-birthdate.Day);
    return string.Format(ageStrinFormat ?? "{0}/{1}/{2}",
        (date.Year - birthdate.Year), date.Month, date.Day);
}
Válaszolt 12/10/2015 13:12
a forrás felhasználó

szavazat
3

Miért nem lehet ilyen egyszerű?

int age = DateTime.Now.AddTicks(0 - dob.Ticks).Year - 1;
Válaszolt 26/06/2015 16:00
a forrás felhasználó

szavazat
3

Ez a klasszikus kérdés érdemes egy Noda Idő megoldás.

static int GetAge(LocalDate dateOfBirth)
{
    Instant now = SystemClock.Instance.Now;

    // The target time zone is important.
    // It should align with the *current physical location* of the person
    // you are talking about.  When the whereabouts of that person are unknown,
    // then you use the time zone of the person who is *asking* for the age.
    // The time zone of birth is irrelevant!

    DateTimeZone zone = DateTimeZoneProviders.Tzdb["America/New_York"];

    LocalDate today = now.InZone(zone).Date;

    Period period = Period.Between(dateOfBirth, today, PeriodUnits.Years);

    return (int) period.Years;
}

Használat:

LocalDate dateOfBirth = new LocalDate(1976, 8, 27);
int age = GetAge(dateOfBirth);

Ön is érdekelt a következő fejlesztéseket tartalmazza:

  • Átadás az óra, mint egy IClock, ahelyett, hogy SystemClock.Instancejavítaná tesztelhetőségi.

  • A cél időzóna valószínűleg változik, ezért azt szeretné, hogy egy DateTimeZoneparaméter is.

Lásd még a blogbejegyzést erről a témáról: Kezelés Születésnapok és egyéb évfordulók

Válaszolt 21/12/2013 05:53
a forrás felhasználó

szavazat
3

Itt egy DateTime extender hozzáteszi, hogy az életkor számítása a DateTime objektumot.

public static class AgeExtender
{
    public static int GetAge(this DateTime dt)
    {
        int d = int.Parse(dt.ToString("yyyyMMdd"));
        int t = int.Parse(DateTime.Today.ToString("yyyyMMdd"));
        return (t-d)/10000;
    }
}
Válaszolt 20/05/2011 17:48
a forrás felhasználó

szavazat
2

Csak használja:

(DateTime.Now - myDate).TotalHours / 8766.0

Az aktuális dátum - myDate = TimeSpan, hogy a teljes órát, és felosztják a teljes órát évente, és kap exacly kor / hónap / nap ...

Válaszolt 15/12/2017 17:27
a forrás felhasználó

szavazat
2

Sokszor számíthat az ujjaim. Meg kell nézni a naptárat, hogy dolgozzanak ki, ha a dolgok változnak. Tehát ez az, amit én cselekszem az én-kód:

int AgeNow(DateTime birthday)
{
    return AgeAt(DateTime.Now, birthday);
}

int AgeAt(DateTime now, DateTime birthday)
{
    return AgeAt(now, birthday, CultureInfo.CurrentCulture.Calendar);
}

int AgeAt(DateTime now, DateTime birthday, Calendar calendar)
{
    // My age has increased on the morning of my 
    // birthday even though I was born in the evening.
    now = now.Date;
    birthday = birthday.Date;

    var age = 0;
    if (now <= birthday) return age; // I am zero now if I am to be born tomorrow.

    while (calendar.AddYears(birthday, age + 1) <= now)
    {
        age++;
    }
    return age;
}

Futó ezt át a LinqPad adja ezt:

PASSED: someone born on 28 February 1964 is age 4 on 28 February 1968
PASSED: someone born on 29 February 1964 is age 3 on 28 February 1968
PASSED: someone born on 31 December 2016 is age 0 on 01 January 2017

Kódot LinqPad van itt

Válaszolt 16/07/2017 10:39
a forrás felhasználó

szavazat
2

Én használtam ezt a kérdést, tudom, hogy ez nem túl elegáns, de működik

DateTime zeroTime = new DateTime(1, 1, 1);
var date1 = new DateTime(1983, 03, 04);
var date2 = DateTime.Now;
var dif = date2 - date1;
int years = (zeroTime + dif).Year - 1;
Log.DebugFormat("Years -->{0}", years);
Válaszolt 05/10/2015 17:09
a forrás felhasználó

szavazat
2

Itt van egy funkció, amely szolgál engem is ... Nem calcs, nagyon egyszerű.

    public static string ToAge(this DateTime dob, DateTime? toDate = null)
    {
        if (!toDate.HasValue)
            toDate = DateTime.Now;
        var now = toDate.Value;

        if (now.CompareTo(dob) < 0)
            return "Future date";

        int years = now.Year - dob.Year;
        int months = now.Month - dob.Month;
        int days = now.Day - dob.Day;

        if (days < 0)
        {
            months--;
            days = DateTime.DaysInMonth(dob.Year, dob.Month) - dob.Day + now.Day;
        }

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


        return string.Format("{0} year(s), {1} month(s), {2} days(s)",
            years,
            months,
            days);
    }

És itt van egy egység teszt:

    [Test]
    public void ToAgeTests()
    {
        var date = new DateTime(2000, 1, 1);
        Assert.AreEqual("0 year(s), 0 month(s), 1 days(s)", new DateTime(1999, 12, 31).ToAge(date));
        Assert.AreEqual("0 year(s), 0 month(s), 0 days(s)", new DateTime(2000, 1, 1).ToAge(date));
        Assert.AreEqual("1 year(s), 0 month(s), 0 days(s)", new DateTime(1999, 1, 1).ToAge(date));
        Assert.AreEqual("0 year(s), 11 month(s), 0 days(s)", new DateTime(1999, 2, 1).ToAge(date));
        Assert.AreEqual("0 year(s), 10 month(s), 25 days(s)", new DateTime(1999, 2, 4).ToAge(date));
        Assert.AreEqual("0 year(s), 10 month(s), 1 days(s)", new DateTime(1999, 2, 28).ToAge(date));

        date = new DateTime(2000, 2, 15);
        Assert.AreEqual("0 year(s), 0 month(s), 28 days(s)", new DateTime(2000, 1, 18).ToAge(date));
    }
Válaszolt 24/06/2015 11:26
a forrás felhasználó

szavazat
2

Szeretném felvenni héber naptár számítások (vagy más System.Globalization naptár lehet használni ugyanúgy) alkalmazásával rewrited funkciók ebben a témában:

Public Shared Function CalculateAge(BirthDate As DateTime) As Integer
    Dim HebCal As New System.Globalization.HebrewCalendar ()
    Dim now = DateTime.Now()
    Dim iAge = HebCal.GetYear(now) - HebCal.GetYear(BirthDate)
    Dim iNowMonth = HebCal.GetMonth(now), iBirthMonth = HebCal.GetMonth(BirthDate)
    If iNowMonth < iBirthMonth Or (iNowMonth = iBirthMonth AndAlso HebCal.GetDayOfMonth(now) < HebCal.GetDayOfMonth(BirthDate)) Then iAge -= 1
    Return iAge
End Function
Válaszolt 11/01/2012 09:58
a forrás felhasználó

szavazat
2

Itt egy kis kódot minta C # I felcsináltak, legyen óvatos széle körül esetekben kifejezetten szökőév, nem minden a fenti megoldások figyelembe veszik azokat. Azáltal, hogy a válasz, mint egy DateTime problémákat okozhat, ahogy a végén próbál tenni túl sok napon át egy adott hónapban pl 30 nap február

public string 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 = 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++;
    }

    return "Years: " + years + " Months: " + months + " Days: " + days;
}
Válaszolt 18/12/2009 15:55
a forrás felhasználó

szavazat
2

Vajon ez a munka?

public override bool IsValid(DateTime value)
{
    _dateOfBirth =  value;
    var yearsOld = (double) (DateTime.Now.Subtract(_dateOfBirth).TotalDays/365);
    if (yearsOld > 18)
        return true;
    return false; 
}
Válaszolt 28/11/2009 02:58
a forrás felhasználó

szavazat
2

Azt hiszem, a TimeSpan olyan, hogy szükségünk van benne, anélkül, hogy igénybe 365,25 (vagy bármely más közelítés). Bővülő augusztus példáját:

DateTime myBD = new DateTime(1980, 10, 10);
TimeSpan difference = DateTime.Now.Subtract(myBD);

textBox1.Text = difference.Years + " years " + difference.Months + " Months " + difference.Days + " days";
Válaszolt 26/09/2008 21:07
a forrás felhasználó

szavazat
1
var birthDate = ... // DOB
var resultDate = DateTime.Now - birthDate;

Használata resultDateakkor lehet alkalmazni, TimeSpaningatlan, amit akarsz megjeleníteni.

Válaszolt 15/02/2018 11:17
a forrás felhasználó

szavazat
1

Itt a legegyszerűbb módja annak, hogy kiszámításához valaki életkora.
Kiszámítása valaki életkora nagyon egyszerű, és itt van, hogyan! Annak érdekében, hogy a program működjön, szükség van egy DateTime objektum neve Születési tartalmazó születésnapját.

 C#
        // get the difference in years
        int years = DateTime.Now.Year - BirthDate.Year; 
        // subtract another year if we're before the
        // birth day in the current year
        if (DateTime.Now.Month < BirthDate.Month || 
            (DateTime.Now.Month == BirthDate.Month && 
            DateTime.Now.Day < BirthDate.Day)) 
            years--;
  VB.NET
        ' get the difference in years
        Dim years As Integer = DateTime.Now.Year - BirthDate.Year
        ' subtract another year if we're before the
        ' birth day in the current year
        If DateTime.Now.Month < BirthDate.Month Or (DateTime.Now.Month = BirthDate.Month And DateTime.Now.Day < BirthDate.Day) Then 
            years = years - 1
        End If
Válaszolt 08/02/2018 15:10
a forrás felhasználó

szavazat
1

Kiszámolni, hogy hány éves egy személy,

DateTime DateOfBirth;

int AgeInYears = DateTime.Now.Year - DateOfBirth.Year;
Válaszolt 31/10/2017 12:09
a forrás felhasználó

szavazat
1

egyszerű Code

 var birthYear=1993;
 var age = DateTime.Now.AddYears(-birthYear).Year;
Válaszolt 27/10/2017 06:43
a forrás felhasználó

szavazat
1

Én csak ezt:

DateTime birthDay = new DateTime(1990, 05, 23);
DateTime age = DateTime.Now - birthDay;

Így lehet kiszámítani a pontos korát a személy, egészen a milliszekundumos, ha akarja.

Válaszolt 02/07/2015 07:37
a forrás felhasználó

szavazat
1

Csak azért, mert én nem gondolom, hogy a legjobb válasz az, hogy egyértelmű:

public static int GetAgeByLoop(DateTime birthday)
{
    var age = -1;

    for (var date = birthday; date < DateTime.Today; date = date.AddYears(1))
        age++;

    return age;
}
Válaszolt 17/02/2015 17:24
a forrás felhasználó

szavazat
1

Hogy lehet, hogy az MSDN segítséget nem mondom, hogy? Úgy néz ki, annyira nyilvánvaló:

System.DateTime birthTime = AskTheUser(myUser); // :-)
System.DateTime now = System.DateTime.Now;
System.TimeSpan age = now - birthTime; //as simple as that
double ageInDays = age.TotalDays; // will you convert to whatever you want yourself?
Válaszolt 19/09/2013 14:15
a forrás felhasználó

szavazat
1

A kevesebb konverziót és UtcNow, ezt a kódot is vigyázni, hogy valaki született február 29 egy szökőév:

public int GetAge(DateTime DateOfBirth)
{
    var Now = DateTime.UtcNow;
    return Now.Year - DateOfBirth.Year -
        (
            (
                Now.Month > DateOfBirth.Month ||
                (Now.Month == DateOfBirth.Month && Now.Day >= DateOfBirth.Day)
            ) ? 0 : 1
        );
}
Válaszolt 08/09/2013 12:01
a forrás felhasználó

szavazat
1

Itt van egy nagyon egyszerű és könnyen követhető példát.

private int CalculateAge()
{
//get birthdate
   DateTime dtBirth = Convert.ToDateTime(BirthDatePicker.Value);
   int byear = dtBirth.Year;
   int bmonth = dtBirth.Month;
   int bday = dtBirth.Day;
   DateTime dtToday = DateTime.Now;
   int tYear = dtToday.Year;
   int tmonth = dtToday.Month;
   int tday = dtToday.Day;
   int age = tYear - byear;
   if (bmonth < tmonth)
       age--;
   else if (bmonth == tmonth && bday>tday)
   {
       age--;
   }
return age;
}
Válaszolt 02/01/2013 17:09
a forrás felhasználó

szavazat
1

Próbálja ki ezt a megoldást, hogy ez működik.

int age = (Int32.Parse(DateTime.Today.ToString("yyyyMMdd")) - 
           Int32.Parse(birthday.ToString("yyyyMMdd rawrrr"))) / 10000;
Válaszolt 04/07/2012 12:28
a forrás felhasználó

szavazat
1

Létrehoztam egy Age struct, ami így néz ki:

public struct Age : IEquatable<Age>, IComparable<Age>
{
    private readonly int _years;
    private readonly int _months;
    private readonly int _days;

    public int Years  { get { return _years; } }
    public int Months { get { return _months; } }
    public int Days { get { return _days; } }

    public Age( int years, int months, int days ) : this()
    {
        _years = years;
        _months = months;
        _days = days;
    }

    public static Age CalculateAge( DateTime dateOfBirth, DateTime date )
    {
        // Here is some logic that ressembles Mike's solution, although it
        // also takes into account months & days.
        // Ommitted for brevity.
        return new Age (years, months, days);
    }

    // Ommited Equality, Comparable, GetHashCode, functionality for brevity.
}
Válaszolt 16/12/2009 10:55
a forrás felhasználó

szavazat
-1

Az egy lineáris válasz,

    DateTime dateOfBirth = Convert.ToDateTime("01/16/1990");
    var age = ((DateTime.Now - dateOfBirth).Days) / 365;
Válaszolt 29/07/2014 12:46
a forrás felhasználó

szavazat
-2

Ezt nézd meg:

TimeSpan ts = DateTime.Now.Subtract(Birthdate);
age = (byte)(ts.TotalDays / 365.25);
Válaszolt 09/05/2015 22:03
a forrás felhasználó

szavazat
-2

Kiszámításához kor legközelebbi kora:

var ts = DateTime.Now - new DateTime(1988, 3, 19);
var age = Math.Round(ts.Days / 365.0);
Válaszolt 03/12/2013 11:14
a forrás felhasználó

szavazat
-3

Nem tetszik sok a választ itt, mert csak néhány sornyi kódot, amit kell egy nagyon egyszerű datemath számítás (kérjük, mentse az összes megjegyzést életkorszámítás más kultúrákban, hacsak nem akarja válasz küldése, amely magában foglalja őket). Az én egy bélés, egyszerű datemath és matematikai függvények, hogy létezik a C #, sqlserver, mysql, stb:

year(@today)-year(@birthDate)+floor((month(@today)-month(@birthdate)+floor((day(@today)-day(@birthdate))/31))/12)

De azt is nagyon hasonlít Mathew válasza felett. Akárhogy is sokkal hatékonyabb, mint a másik adott válaszokat itt.

Válaszolt 23/07/2015 16:03
a forrás felhasználó

szavazat
-3
int age = DateTime.Now.Year - birthday.Year;
if (DateTime.Now.Month < birthday.Month || DateTime.Now.Month == birthday.Month 
&& DateTime.Now.Day < birthday.Day) age--;
Válaszolt 11/06/2014 12:23
a forrás felhasználó

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more