Excel'de 1/1/1900 öncesi yaşları hesaplama

Özet

Microsoft Excel tarih formülleri yalnızca 1/1/1/1900 ile 31.12.9999 arasında girilen tarihleri kullanabilse de, özel bir Microsoft Visual Basic for Applications işlevini kullanarak birinin veya 1 Ocak 1900'ün öncesinde oluşturulmuş bir şeyin yaşını (yıl olarak) hesaplayabilirsiniz.

Yaşı Hesaplamak için Makro Kullanma

Microsoft, programlama örneklerini yalnızca gösterim amacıyla sağlar; örtülü veya açık garanti vermez. Buna zımni garantiler, satılabilirlik veya belirli bir amaca uygunluk da dahildir, ancak bunlarla sınırlı değildir. Bu makale, gösterilen programlama dilini ve yordamları oluşturmak ve hata ayıklamak amacıyla kullanılan araçları kullanmayı bildiğinizi varsayar. Microsoft destek mühendisleri, belirli bir yordamın işlevselliğinin açıklanmasına yardımcı olabilir, ancak gereksinimlerinizi karşılamaya yönelik olarak ek işlevsellik sağlamak veya yordamlar geliştirmek amacıyla bu örnekleri değiştirmezler.

Excel, 1/1/1900'e kadar olan tarihleri metin olarak girer. Bu işlev, 1/1/0001 ile başlayan metin olarak girilen tarihler, normal tarihler için çalışır ve başlangıç tarihi 1900'den önceki ve bitiş tarihi 1900'den sonraki tarihleri işleyebilir. Makroyu kullanmak için şu adımları izleyin:

  1. Excel'i başlatın. İşlevini kullanmak istediğiniz çalışma sayfasını görüntüleyin.

  2. Visual Basic Düzenleyici geçmek için ALT+F11 tuşlarına basın.

  3. Ekle menüsünde, Modül'e tıklayın.

  4. Modülde aşağıdaki kodu yazın:

    ' This is the initial function. It takes in a start date and an end date.
    Public Function AgeFunc(stdate As Variant, endate As Variant)
    
        ' Dim our variables.
        Dim stvar As String
        Dim stmon As String
        Dim stday As String
        Dim styr As String
        Dim endvar As String
        Dim endmon As String
        Dim endday As String
        Dim endyr As String
        Dim stmonf As Integer
        Dim stdayf As Integer
        Dim styrf As Integer
        Dim endmonf As Integer
        Dim enddayf As Integer
        Dim endyrf As Integer
        Dim years As Integer
    
        ' This variable will be used to modify string length.
        Dim fx As Integer
        fx = 0
    
        ' Calls custom function sfunc which runs the Search worksheet function
        ' and returns the results.
        ' Searches for the first "/" sign in the start date.
        stvar = sfunc("/", stdate)
    
        ' Parse the month and day from the start date.
        stmon = Left(stdate, sfunc("/", stdate) - 1)
        stday = Mid(stdate, stvar + 1, sfunc("/", stdate, sfunc("/", stdate) + 1) - stvar - 1)
    
        ' Check the length of the day and month strings and modify the string 
        ' length variable.
        If Len(stday) = 1 Then fx = fx + 1
        If Len(stmon) = 2 Then fx = fx + 1
    
        ' Parse the year, using information from the string length variable.
        styr = Right(stdate, Len(stdate) - (sfunc("/", stdate) + 1) - stvar + fx)
    
        ' Change the text values we obtained to integers for calculation 
        ' purposes.
        stmonf = CInt(stmon)
        stdayf = CInt(stday)
        styrf = CInt(styr)
    
        ' Check for valid date entries.
        If stmonf < 1 Or stmonf > 12 Or stdayf < 1 Or stdayf > 31 Or styrf < 1 Then
            AgeFunc = "Invalid Date"
            Exit Function
        End If
    
        ' Reset the string length variable.
        fx = 0
    
        ' Parse the first "/" sign from the end date.
        endvar = sfunc("/", endate)
    
       ' Parse the month and day from the end date.
        endmon = Left(endate, sfunc("/", endate) - 1)
        endday = Mid(endate, endvar + 1, sfunc("/", endate, sfunc("/", endate) + 1) - endvar - 1)
    
        ' Check the length of the day and month strings and modify the string 
        ' length variable.
        If Len(endday) = 1 Then fx = fx + 1
        If Len(endmon) = 2 Then fx = fx + 1
    
        ' Parse the year, using information from the string length variable.
        endyr = Right(endate, Len(endate) - (sfunc("/", endate) + 1) - endvar + fx)
    
        ' Change the text values we obtained to integers for calculation 
        ' purposes.
        endmonf = CInt(endmon)
        enddayf = CInt(endday)
        endyrf = CInt(endyr)
    
        ' Check for valid date entries.
        If endmonf < 1 Or endmonf > 12 Or enddayf < 1 Or enddayf > 31 Or endyrf < 1 Then
            AgeFunc = "Invalid Date"
            Exit Function
        End If
    
        ' Determine the initial number of years by subtracting the first and 
        ' second year.
        years = endyrf - styrf
    
        ' Look at the month and day values to make sure a full year has passed. 
        If stmonf > endmonf Then
            years = years - 1
        End If
    
    If stmonf = endmonf And stdayf > enddayf Then
            years = years - 1
        End If
    
        ' Make sure that we are not returning a negative number and, if not, 
        ' return the years.
        If years < 0 Then
            AgeFunc = "Invalid Date"
        Else
            AgeFunc = years
        End If
    
    End Function
    
    ' This is a second function that the first will call.
    ' It runs the Search worksheet function with arguments passed from AgeFunc.
    ' It is used so that the code is easier to read.
    Public Function sfunc(x As Variant, y As Variant, Optional z As Variant)
        sfunc = Application.WorksheetFunction.Search(x, y, z)
    End Function
    
  5. Dosyayı kaydedin.

  6. Aşağıdaki verileri yazın:

     A1 01/01/1887
     A2 02/02/1945
    

    A3 hücresine aşağıdaki formülü girin:

    =AgeFunc(startdate,enddate)
    

    Başlangıç tarihi, ilk tarihinize (A1) yapılan bir hücre başvurusu, bitiş tarihi ise ikinci tarihinize (A2) yönelik bir hücre başvurusudur.

    Sonuç 58 olmalıdır.

Not

1/1/1900'e kadar olan tüm tarihlerin geçerli olup olmadığını denetleyin. Metin olarak girilen tarihler Excel tarafından denetlenmiyor.

Başvurular

Bu makaledeki örnek kodu kullanma hakkında daha fazla bilgi için bkz. Office 2010'da Bilgi Bankası Makalelerinden örnek kod çalıştırma.