forked from jet-c-21/Horus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathface_enrollment.py
45 lines (33 loc) · 1.04 KB
/
face_enrollment.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
"""
author: Jet Chien
GitHub: https://github.com/jet-chien
Create Date: 2021/1/13
"""
# coding: utf-8
from pandas import DataFrame
from FaceRecog.horus_toolkit import gen_member_id
from FaceRecog.horus_toolkit.db_tool import get_db_conn, get_table_df_with_conn, insert_data_with_conn
def gen_new_mid(table_df: DataFrame) -> str:
used_mid = table_df['mid'].values
new_mid = ''
flag = True
while flag:
new_mid = gen_member_id()
if new_mid not in used_mid:
flag = False
return new_mid
def enroll_with_pkl(pkl_path: str):
conn = get_db_conn()
table_df = get_table_df_with_conn(conn, TABLE_NAME)
new_mid = gen_new_mid(table_df)
data = {'mid': new_mid, 'face_img': pkl_path}
insert_data_with_conn(conn, TABLE_NAME, data)
conn.commit()
conn.close()
print(f"new member: {new_mid} was added.")
if __name__ == '__main__':
TABLE_NAME = 'member'
pickle_path = 'mf_data/jet.pkl'
enroll_with_pkl(pickle_path)
pickle_path = 'mf_data/lotus.pkl'
enroll_with_pkl(pickle_path)