您好,登錄后才能下訂單哦!
這篇文章主要介紹了怎么用Python編寫一個電子考勤系統,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
學校現在需要實現一個電子考勤系統,考慮到你們班已經學過大數據應用開發語言Python,準備讓你們實現部分學生端考勤功能。經過和老師的溝通,你了解到:
(1) 目前該系統已經被學長實現了部分功能,你們只需要完成剩余功能即可,需要你們完成的功能會使用
#todo的形式進行標注, todo后面會列出這個地方的功能,形式如下。
(2) 學生信息存儲在stu_infos.csv文件中,第一行是列名行,后面每一行都是一個學生的信息,包含學號,姓名,密碼。內容形式如下:
(3) 考勤記錄最終會被保存到attendance.csv文件中,第一行是列名行,后面每一行代表一個學生的考勤信息,包含學號,姓名,時間,考勤狀態(只有出勤、遲到、請假、缺勤四種狀態)。內容格式如下:
(4) 學生信息需要首先被加載到student_infos列表中,student_info中的每個元素都是一個字典,字典中的鍵都是各自列名,而值則是每一行內容,按照示例數據構造出來的student_infos列表如下。
(5) 考勤系統老師端總共有兩個Python文件,一個main.py文件,該文件作為入口程序文件,實現主體框架,主體流程就是:加載數據 登錄 添加考勤數據;一個stu_attendance.py文件,定義了數據加載、登錄等函數。
答題要求:
(1) 在stu_info.csv文件末尾添加一行自己的信息,密碼隨意寫,名字和學號必須是自己
(2) 查看兩個Python文件中的todo注釋,添加合適代碼,最終提供添加的代碼。
(3) 測試程序功能,提供程序運行截圖。進行登錄驗證的時候使用自己的學號進行登錄驗證,并且需要測試如下2個分支:3次都登錄失敗的情況、登錄成功后成功添加考勤數據。
附加功能
添加一個查詢功能,輸入一個學生的姓名就可以獲取他的出勤數據信息
導入模塊
import csv import time student_infos = []
加載數據
def load_stu_info(): """ 加載學生信息 從stu_infos.csv文件中加載數據 :return: 無 """ with open(r"stu_infos.csv", encoding='utf-8-sig') as file: f_csv = csv.reader(file) header = next(f_csv) for row in f_csv: student_info = {} for index in range(3): student_info[header[index]] = row[index] student_infos.append(student_info)
登錄
def login(): """ 用戶使用學號和密碼進行登錄 最多讓用戶登錄三次,如果連續三次都登錄失敗(用戶名或者密碼錯誤),只要密碼和用戶都正確表示登錄成功 :return:登錄成功返回True和學號,三次都登錄失敗返回False和None """ retry_time = 0 while retry_time < 3: user_no = input('請輸入登錄賬號:') password = input('請輸入密碼:') for i in student_infos: if i['no']==user_no and i['password']==password: return True,user_no print('用戶名或者密碼錯誤!!!請重新輸入。') retry_time += 1 else: return False, None
考勤記錄寫入
def add(user_no): for x in student_infos: if user_no==x['no']: name=x['name'] break times=time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) choices=['出勤','遲到','請假','缺勤'] a=int(input("\t該學生出勤情況:1-出勤\t2-遲到\t3-請假\t4-缺勤:")) if a==1: data=choices[0] elif a==2: data=choices[1] elif a==3: data=choices[2] else: data=choices[3] with open(r"attendance.csv",'a+',newline='', encoding='utf-8') as f: wf = csv.writer(f) wf.writerow([user_no,name,times,data])#寫入一行數據 print("{}同學{}數據已經寫入成功!操作時間是{}".format(name,data,times))
查詢考勤記錄
def select(): student = [] with open(r"attendance.csv", encoding='utf-8-sig') as file: f_csv = csv.reader(file) header = next(f_csv) for row in f_csv: students = {} for index in range(4): students[header[index]] = row[index] student.append(students) name=input("請輸入你需要查找的姓名:") print(" 學號\t\t姓名\t\t操作時間\t\t出勤狀態") for a in student: if a['name']==name: print(a['no']+'\t'+a['name']+'\t'+a['time']+'\t\t'+a['state']) else: print("無此人!!!") break
主函數我就不給出了,有需要的可以自己編寫一下,如果需要可以私信我或者在這里下載數據集和源碼喲!!!
點擊下載!
看看運行效果喲!
感謝你能夠認真閱讀完這篇文章,希望小編分享的“怎么用Python編寫一個電子考勤系統”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。