-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutils.py
32 lines (27 loc) · 1.04 KB
/
utils.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
import pandas as pd
import json
def extract_data_from_excel(file_path, fullname_col, rollno_col, dob_col):
df = pd.read_excel(file_path)
data = []
for index, row in df.iterrows():
# print(row)
roll_number = row.get(rollno_col)
name = row.get(fullname_col)
dob = row.get(dob_col)
if pd.notna(roll_number) and pd.notna(name) and pd.notna(dob):
if not isinstance(dob, pd.Timestamp):
try:
dob = pd.to_datetime(dob, errors='coerce')
except Exception as e:
print(f"Error converting date for row {row}: {e}")
dob = None
# Format dob if conversion was successful
# if csjmu '%m/%d/%Y'
# if aktu '%d/%m/%Y'
dob_str = dob.strftime('%m/%d/%Y') if pd.notna(dob) else "Invalid Date"
data.append({
'name': name,
'rollno': int(roll_number),
'dob': dob_str
})
return data