-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
75 lines (63 loc) · 2.91 KB
/
app.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
import streamlit as st
import pandas as pd
import os
from takeimages import capture_images
from train import train_model
from test import recognize_faces_live
from datetime import datetime
def save_student_details(name, roll_number):
if not os.path.exists('students.csv'):
df = pd.DataFrame(columns=['Name', 'RollNumber'])
else:
df = pd.read_csv('students.csv')
if not ((df['Name'] == name) & (df['RollNumber'] == roll_number)).any():
new_entry = pd.DataFrame({'Name': [name], 'RollNumber': [roll_number]})
df = pd.concat([df, new_entry], ignore_index=True)
df.drop_duplicates(subset=['Name', 'RollNumber'], keep='first', inplace=True)
df.to_csv('students.csv', index=False)
else:
st.warning("Student already registered")
def mark_attendance(name, roll_number):
date = datetime.now().strftime('%Y-%m-%d')
if not os.path.exists('attendance.csv'):
df = pd.DataFrame(columns=['Name', 'RollNumber', 'Date', 'Present'])
else:
df = pd.read_csv('attendance.csv')
if not ((df['Name'] == name) & (df['RollNumber'] == roll_number) & (df['Date'] == date)).any():
new_entry = pd.DataFrame({'Name': [name], 'RollNumber': [roll_number], 'Date': [date], 'Present': ['Yes']})
df = pd.concat([df, new_entry], ignore_index=True)
df.to_csv('attendance.csv', index=False)
st.title("Attendance Management System")
menu = ["Register Student", "Attendance", "View Databases"]
choice = st.sidebar.selectbox("Menu", menu)
if choice == "Register Student":
st.subheader("Register Student")
name = st.text_input("Enter the name of the student:", value="", max_chars=50, key="name", help="This field is required.")
roll_number = st.text_input("Enter the roll number of the student:", value="", max_chars=20, key="roll_number", help="This field is required.")
if st.button("Register"):
if name and roll_number:
save_student_details(name, roll_number)
capture_images(f"{name}-{roll_number}")
train_model()
st.success(f"Student {name} registered")
else:
st.error("Please fill in all required fields.")
elif choice == "Attendance":
st.subheader("Attendance")
if st.button("Start Attendance"):
recognize_faces_live(mark_attendance)
st.success("Attendance recorded")
elif choice == "View Databases":
st.subheader("Student Database")
if os.path.exists('students.csv'):
students_df = pd.read_csv('students.csv')
students_df.drop_duplicates(subset=['Name', 'RollNumber'], keep='first', inplace=True)
st.dataframe(students_df)
else:
st.write("No student data available.")
st.subheader("Attendance Database")
if os.path.exists('attendance.csv'):
attendance_df = pd.read_csv('attendance.csv')
st.dataframe(attendance_df)
else:
st.write("No attendance data available.")