-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgedcomFileParser.py
103 lines (97 loc) · 4.52 KB
/
gedcomFileParser.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
from datetime import date
from datetime import datetime
from classModels import gedcomLineClass, individualsClass, familiesClass
import math
# Function to Parse the GEDCOM file
def GEDCOMFileParser(filename):
listOfIndividuals = []
listOfFamilies = []
gedlist = []
f = open(filename)
lines = [line.rstrip('\n\r') for line in f]
for line in lines:
current_gedcom = gedcomLineClass(line)
gedlist.append(current_gedcom)
for index, gedcomline in enumerate(gedlist):
#for storing individual person details
if gedcomline.tag == 'INDI':
date_type = None
individualsClassObject = individualsClass(gedcomline.ref)
for gedline in gedlist[index + 1:]:
if gedline.level == 0:
break
if gedline.tag == "NAME":
individualsClassObject.name = gedline.arg
if gedline.tag == "SEX":
individualsClassObject.gender = gedline.arg[0]
if gedline.tag == "BIRT":
date_type = "BIRT"
if gedline.tag == "DEAT":
date_type = "DEAT"
if gedline.tag == "FAMC":
individualsClassObject.child.append(gedline.arg[0])
if gedline.tag == "FAMS":
individualsClassObject.spouse.append(gedline.arg[0])
if gedline.tag == 'DATE':
if date_type == 'BIRT':
individualsClassObject.birthday = date(
int(gedline.arg[2]),
datetime.strptime(gedline.arg[1], '%b').month,
int(gedline.arg[0])
)
birthDate = date(
int(gedline.arg[2]),
datetime.strptime(gedline.arg[1], '%b').month,
int(gedline.arg[0])
)
age = (datetime.today().date() - birthDate).days / 365
individualsClassObject.age = math.floor(age)
date_type = None
elif date_type == 'DEAT':
individualsClassObject.death = date(
int(gedline.arg[2]),
datetime.strptime(gedline.arg[1], '%b').month,
int(gedline.arg[0])
)
individualsClassObject.alive = False
date_type = None
listOfIndividuals.append(individualsClassObject)
# For storing family details
if gedcomline.tag == 'FAM':
date_type = None
familyObject = familiesClass(gedcomline.ref)
for gedline in gedlist[index + 1:]:
if gedline.level == 0:
break
if gedline.tag == "MARR":
date_type = "MARR"
if gedline.tag == "DIV":
date_type = "DIV"
if gedline.tag == "HUSB":
familyObject.husbandId = gedline.arg[0]
for persons in listOfIndividuals:
if persons.id == gedline.arg[0]:
familyObject.husbandName = persons.name
if gedline.tag == "WIFE":
familyObject.wifeId = gedline.arg[0]
for persons in listOfIndividuals:
if persons.id == gedline.arg[0]:
familyObject.wifeName = persons.name
if gedline.tag == "CHIL":
familyObject.children.append(gedline.arg[0])
if gedline.tag == "DATE":
if date_type == "MARR":
familyObject.married = date(
int(gedline.arg[2]),
datetime.strptime(gedline.arg[1], '%b').month,
int(gedline.arg[0]))
date_type = None
elif date_type == "DIV":
familyObject.divorced = date(
int(gedline.arg[2]),
datetime.strptime(gedline.arg[1], '%b').month,
int(gedline.arg[0]))
date_type = None
listOfFamilies.append(familyObject)
f.close()
return listOfIndividuals, listOfFamilies