Changes

Jump to: navigation, search

Dates

3,073 bytes added, 22:05, 18 March 2022
See also
{{stub}}This page documents advanced features of GRAMPS Gramps dates.
= Dates =
Dates in GRAMPS Gramps are much more complex than just a month, day, and year. Dates are always in a particular calendar, can span a time frame, can be approximate, and have support for many other subtleties specific to genealogy data.
;The Date Editor in GRAMPS Gramps 3.0 looked like:
[[ImageFile:Date-selection.png|left|thumb|450px|Date Editor in Gramps 3.0]]{{-}}In GRAMPS Gramps 3.1, we have added two features for dates:
* full support for '''dual dated''' dates
Some locations changed from the Julian calendar to the Gregorian calendar at the same time that they changed the new year from March 25 to January 1. However, in many places in the world these two events did not happen at the same time.
;The new Gramps 3.1 data entry screen currently looks like: [[Image:DualDated.png]]
[[File:DualDated.png|left|thumb|450px|Date Editor in Gramps 3.1]]
{{-}}
== Dual Dated ==
From [2]: "For example, England and the American colonies didn't officially accept the new calendar until 1752. Before 1752, the English government still observed March 25 as the first of the year, but most of the population observed January 1 as the first of the year. For this reason, many people wrote dates falling between January 1 and March 25 with both years..."
Sometimes, a dual date may appear as a fraction, as in this grave stone(170 and 3/4, which means 1703 and 1704)[[Image:Gravestone.jpg]]
[[File:Gravestone.jpg|left|thumb|450px]]
{{-}}
Marking a date as '''dual dated''' can be done by simply putting a slash between the years. For example:
* 1721/2
* 1719/20
* 1799/800
These slash-years can appear anywhere in a date that a regular year can appear.
* Feb 23, 1710/1 (Mar25)
Note that if new year's day is not Jan 1, then January may come after December that year! Dates with new year day codes will be sorted appropriately. For example, using the [[Addon:Python Shell Gramplet|Python Gramplet]]:
<pre>
> dates = ["Dec 31, 1720", "Jan 1, 1720", "Mar 1, 1720", "Mar 25, 1720", "Mar 26, 1720", "Dec 1, 1720"]
> dates.sort(cmpkey=lambda a,bx: cmp(Date(a).sortval, Date(b).sortvalx))
> dates
['Jan 1, 1720', 'Mar 1, 1720', 'Mar 25, 1720', 'Mar 26, 1720', 'Dec 1, 1720', 'Dec 31, 1720']
> dates.sort(cmpkey=lambda a,bx: cmp(Date(a x + " (Mar25)").sortval, Date(b + " (Mar25)").sortval))
> dates
['Mar 25, 1720', 'Mar 26, 1720', 'Dec 1, 1720', 'Jan 1, 1720', 'Dec 31, 1720', 'Mar 1, 1720']
</pre>
This creates a list of date strings. You can sort them by wrapping Date() around them, and using their sortvalcomparing to another Date. In the first example, they have a normal, January through December ordering.
In the second example we append a " (Mar25)" after the date. Now when we sort, we see that the year begins with Mar, followed by all of the months up to Dec, then Jan, Feb and the first part of March is last.
 
Likewise, date differences can also be made with this method. For example, consider the two dates, '''Jan 1, 1750''' and '''Dec 1, 1750'''. Without considering what was the first day of the year with normal sequencing, those dates are 11 months apart. However, if they are actually separated by the new year, then they are actually only a month apart, and the first follows the second:
 
<pre>
> Date("Dec 1, 1750") - Date("Jan 1, 1750")
11 months
> Date("Dec 1, 1750 (Mar25)") - Date("Jan 1, 1750 (Mar25)")
-1 month, -1 day
</pre>
 
== Date Math ==
 
The Date object in Gramps 3.1 has been enhanced in the way that dates are compared to one another. There are actually three different uses for comparing dates:
 
# for sorting (eg, for listing in a table)
# for describing (eg, for describing an age)
# for ranking (eg, for computing "record holding" spans)
 
=== Date Differences ===
 
When a date is subtracted from another, a Span is created. A date Span can be used for creating a textual representation of the difference. A Span can also be used for ranking the difference, including a minimum difference, and a maximum difference.
 
=== Date Comparisons ===
 
There are three methods for seeing if one date happened before another date:
 
# simple method: date1.sortval < date2.sortval
# more sophisticated and expensive: date1.match(date2' "<")
# more restrictive: date1.match(date2, "<<")
 
Likewise for seeing if two dates are the same:
 
# simple method: date1.sortval == date2.sortval
# more sophisticated and expensive: date1.match(date2' "=")
 
and for seeing if one date happened after another date:
 
# simple method: date1.sortval > date2.sortval
# more sophisticated and expensive: date1.match(date2' ">")
# more restrictive: date1.match(date2, ">>")
= References =
# http://www.genealogy.com/00000771.html
# http://en.wikipedia.org/wiki/New_Year
 
==Related Gramps bugs==
# <s>{{bug|1133}}</s>: Dates in Event view do not display in chronological order
# <s>{{bug|1834}}</s>: Dates do not respect new-year boundaries in history
# <s>{{bug|1842}}</s>: Editing double-dated dates (slash) in GUI box loses slash
# <s>{{bug|2260}}</s>: fractional year dates not interpreted correctly
 
= See also =
* [[Gramps_Glossary#date|Gramps Glossary : Date]]
* [[Mixed date|Support of mixed Julian/Gregorian calendar dates]]
* [[Match dates|Matching dates in filters &amp; searches]]
* [[Gramps_{{Version manual}}_Wiki_Manual_-_Entering_and_editing_data:_detailed_-_part_1#Editing_dates|Data entry &amp; editing : Dates]]
* [[Gramps_{{Version manual}}_Wiki_Manual_-_Reports_-_part_2#Formatting_Dates|Reports : Formatting dates]]
* [[Date_Handler|Localization support : Date Handler]]
* [[Test_date_handlers|Localization support : Test Date Handlers]]
* [[Addon:Calculate Estimated Dates|Calculate Estimated Dates]] (tool addon)
* [[Addon:DateCalculator|Date Calculator]] (Gramplet addon)
 
 
[[Category:Developers/General]]
[[Category:Documentation]]
1,969
edits

Navigation menu