Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cfinke/PHP-GEDCOM-Tools
PHP scripts for interacting with GEDCOM files.
https://github.com/cfinke/PHP-GEDCOM-Tools
Last synced: 2 months ago
JSON representation
PHP scripts for interacting with GEDCOM files.
- Host: GitHub
- URL: https://github.com/cfinke/PHP-GEDCOM-Tools
- Owner: cfinke
- License: mit
- Created: 2014-07-11T00:20:53.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2015-12-06T05:30:08.000Z (about 9 years ago)
- Last Synced: 2024-08-04T04:05:18.674Z (6 months ago)
- Language: PHP
- Homepage:
- Size: 192 KB
- Stars: 12
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gedcom - PHP-GEDCOM-Tools - PHP scripts for interacting with GEDCOM files (Parsers / PHP)
README
PHP GEDCOM Tools
================Tools for interacting with GEDCOM (family tree) files. These have only been tested on a very small sample, but maybe they'll come in handy for you.
export-branch.php
-----------------
Export a new GEDCOM file containing only the person specified, their descendants and descendants' spouses, and any events or other entries related to those people.This is handy for when you have a massive family tree constructed but would like to share only a portion of it with someone else.
Usage:
`./scripts/export-branch.php --gedcom=/path/to/existing-tree.ged --person='John Doe' --out=/path/to/new-tree.ged`
The `--person` argument must match exactly the name of the person you want at the top of the tree.
export-related.php
------------------
Export a new GEDCOM file containing only the person specified and any other people related by blood. This will exclude spouses of blood relatives, but would include, for example, children, grandchildren, cousins, grandparents, and half-siblings.Usage:
`./scripts/export-related.php --gedcom=/path/to/existing-tree.ged --person='John Doe' --out=/path/to/new-tree.ged`
The `--branch` argument must match exactly the name of the person you want the tree based on.
death-age-stats.php
-------------------
Calculate the average and median age at death for everyone in a GEDCOM file.Usage:
`./scripts/death-age-stats.php --gedcom=/path/to/existing-tree.ged --age=[minimum age at death] --sex=[M|F]`
The optional `--age` parameter can be used to specify a minimum age at death to find, for example, the median age at death of all family members that didn't die before the age of 30.
The optional `--sex` parameter can be used to filter the results by gender.
Example output:
```
Average age at death: 56 years
Median age at death: 69 years
```death-age-stats-over-time.php
-----------------------------
Calculate the average and median age at death for everyone in a GEDCOM file, subdivided by year or decade of death.Usage:
`./scripts/death-age-stats-over-time.php --gedcom=/path/to/existing-tree.ged --timeframe=[year|decade] --sex=[M|F]`
The optional `--timeframe` parameter can be used to specify how to report the results. The default value is `year`.
The optional `--sex` parameter can be used to filter the results by gender.
Example output:
```
Year Average Median
1870 50 64
1880 36 45
1890 59 77
1900 55 61.5
1910 46 32
[...]
1970 70 73.5
1980 78 79
1990 80 84.5
2000 83 87
2010 87 85.5
```gender-counts.php
-----------------
Tally the count of the genders represented in a GEDCOM file.Usage:
`./scripts/gender-counts.php --gedcom=/path/to/existing-tree.ged`
Example output:
```
M: 1340
F: 1198
```date-histogram.php
------------------
Print a histogram of date (month/day) frequencies for a given event type.Usage:
`./scripts/date-histogram.php --gedcom=/path/to/existing-tree.ged --type=[BIRT|DEAT|MARR] --specificity=[day|month] --histogram=[X|counts|cloud-raw]`
Supported `--type` values are `BIRT` (birth), `DEAT` (death), and `MARR` (marriage).
Supported values for the optional `--specificity` argument are `day` and `month`.
The optional `--histogram` parameter determines how the histogram is output. `X` is default and generates the example below. `counts` generates tab-delimited data suitable for pasting into a spreadsheet. `cloud-raw` generates text suitable for pasting into a word cloud generator.
Example output using `--specificity=day`.
```
01-01 XX
01-02 X
01-03 X
01-04 XX
01-05 XX
01-06 XX
01-07 XXXXX
01-08 XXXX
01-09
01-10 XXX
01-11 XXXX
01-12 XXX
[...]
12-20 XXXXX
12-21 XXXX
12-22 XXXXXXX
12-23 XX
12-24 XXXX
12-25
12-26 X
12-27
12-28 XX
12-29 XXXX
12-30 XXX
12-31 X
```and `month`:
```
01 XXXXXXXXXXXXXXXXXXX
02 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
03 XXXXXXXXXXXXXXXXXXXX
04 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
05 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
06 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
07 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
08 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
09 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
10 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
11 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
12 XXXXXXXXXXXXXXXXXXXXXXXXXXXXX
```name-histogram.php
------------------
Generate a histogram of name frequency in a GEDCOM file.Usage:
`./scripts/name-histogram.php --gedcom=/path/to/existing-tree.ged --sex=[M|F] --histogram=[X|counts|cloud-raw]`
The optional `--sex` parameter can be used to filter the results by gender.
The optional `--histogram` parameter determines how the histogram is output. `X` is default and generates the example below. `counts` generates tab-delimited data suitable for pasting into a spreadsheet. `cloud-raw` generates text suitable for pasting into a word cloud generator.
Example output:
```
Marie XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Ann XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
John XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Lee XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Michael XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
William XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
[...]
Evelyn XXX
Wilma XX
Adele XX
Reka X
Laurel X
Friedericke X
```death-note-histogram.php
------------------------
Generate a histogram of word frequency in for all DEAT entries in a GEDCOM file.Usage:
`./scripts/death-note-histogram.php --gedcom=/path/to/existing-tree.ged --sex=[M|F] --histogram=[X|counts|cloud-raw]`
The optional `--sex` parameter can be used to filter the results by gender.
The optional `--histogram` parameter determines how the histogram is output. `X` is default and generates the example below. `counts` generates tab-delimited data suitable for pasting into a spreadsheet. `cloud-raw` generates text suitable for pasting into a word cloud generator.
Example output:
```
cancer XXXXXXXXXX
heart XXXXXXXXX
accident XXXXXXX
attack XXXXXX
pneumonia XXXXXX
[...]
drowning X
childbirth X
encephalo X
```age-histogram.php
-----------------
Generate a histogram of the ages of individuals in the tree at certain events in their lives (marriage or death).Usage:
`./scripts/age-histogram.php --gedcom=/path/to/existing-tree.ged --type=[BIRT|DEAT] --histogram=[X|counts|cloud-raw]`
The optional `--histogram` parameter determines how the histogram is output. `X` is default and generates the example below. `counts` generates tab-delimited data suitable for pasting into a spreadsheet. `cloud-raw` generates text suitable for pasting into a word cloud generator.
Example output:
```
0
[...]
15 X
16 XXX
17 XXXX
18 XXXXXXXXXXXXXXXX
19 XXXXXXXXXXXXXXXXXXXXXXXX
20 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
21 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
22 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
23 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
24 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
25 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
26 XXXXXXXXXXXXXXXXXXXXXXXX
27 XXXXXXXXXXXXXXXXXXXX
28 XXXXXXXXXXXXX
29 XXXXXXXXXXXX
30 XXXXXXXXXXXX
31 XXXXXXXXXX
32 XXXXXXX
33 XXX
[...]
70
```place-progression.php
---------------------
Generate an animated GIF showing birth or death locations on a map over time. United States-only, requires `ImageMagick` and `gifsicle`.Usage:
`./scripts/place-progression.php --gedcom=/path/to/existing-tree.ged --type=[BIRT|DEAT] --out=/path/to/output.gif --key=[optional Google API key] --icon=[URL of optional icon to use as map marker]`
The `--key` parameter is optional; provide your Google API key in order to avoid rate limiting by IP for the mapping API calls.
The `--icon` parameter is optional; provide the URL of an image to use to mark the map for births/deaths. Note that only its shape will be used; the markers will all be solid red in color.
Example output:
![](assets/birth-places.gif)
missing-death-dates.php
-----------------------
Output a list of people who are most likely dead but do not have death dates in the GEDCOM file.Usage:
`./scripts/missing-death-dates.php --gedcom=/path/to/existing-tree.ged --age=[minimum age to consider dead]`
The `--age` parameter is optional; the default is 120 (years).
Example output:
```
Jacob Lenz, born 1754
Peter Lenz, born 1757
Peter Koglin, born about 1765
[...]
Lydia Emily Latzke, born 15 Jun 1912
Marie Marthan Siewert, born 6 Oct 1912
Otto E Siewert Jr., born 10 Oct 1913
```relationship-inconsistencies.php
--------------------------------
Output a list of relationships that are inconsistent and possibly contain errors.Usage:
`./scripts/missing-death-dates.php --gedcom=/path/to/existing-tree.ged`
Example output:
```
Paul Hoese (16 Jan 1874) was born after their mother, Jane Hoese, turned 60 (born 24 Sep 1813)
Carl Lenz (1850) was born after their mother, Christina Lenz, died (born 26 Sep 1797)
[...]
Vicky Smith (2 Apr 1932) was born before their parent, Shirley Smith, turned 15 (born abt 1922)
Justin Jones (2 Jul 1971) was born before their parent, Harold Jones (born 7 Sept 1972)
```child-count-histogram.php
-------------------------
Print a histogram showing the distribution of the number of children per family (for families that have children).Usage:
`./scripts/child-count-histogram.php --gedcom=/path/to/existing-tree.ged --histogram=[X|counts|cloud-raw]`
The optional `--histogram` parameter determines how the histogram is output. `X` is default and generates the example below. `counts` generates tab-delimited data suitable for pasting into a spreadsheet. `cloud-raw` generates text suitable for pasting into a word cloud generator.
Example output:
```
1 XXXXXXXXXXXXXXXXXX
2 XXXXXXXXXXXXXXXXXXXXXXXX
3 XXXXXXXXXXXXXXXXXXXXXXX
[...]
12 XXX
13 XX
14 X
```