项目简介

学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应用开发语言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 = 0while 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_noprint('用户名或者密码错误!!!请重新输入。')retry_time += 1else:return False, None

考勤记录写入

def add(user_no):for x in student_infos:if user_no==x['no']:name=x['name']breaktimes=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

主函数我就不给出了,可以自己编写一下,如果需要可以下载下边的数据集和源码哟~

链接: https://pan.baidu.com/s/1-dthS7c27oH3HCFWev7nWQ

提取码: tbhg

运行效果:

PS:如果觉得我的分享不错,欢迎大家随手点赞、在看。

用Python写了一个电子考勤系统相关推荐

  1. 用Python写了一个电子考勤系统!

    今天给大家分享一个比较有意思的Python应用,用 Python 写了一个电子考勤系统,源码已在文章全部给出,记得点赞收藏哦- 项目简介 学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应 ...

  2. 耗时半年,用 Python 写了一个电子考勤系统

    今天给大家分享一个比较有意思的 Python 应用,用 Python 写了一个电子考勤系统,源码获取在下方文章中给出,记得点赞收藏哦- 文章目录 电子考勤完整代码 项目简介 答题要求 附加功能 导入模 ...

  3. 用 Python 写了一个电子考勤系统!

    今天给大家分享一个比较有意思的Python应用,用 Python 写了一个电子考勤系统,源码已在文章全部给出,记得点赞收藏哦- 项目简介 学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应 ...

  4. 用 Python 写了一个电子考勤系统

    学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应用开发语言Python,准备让你们实现部分学生端考勤功能.经过和老师的沟通,你了解到: (1) 目前该系统已经被学长实现了部分功能,你们只 ...

  5. 我通过Python给我们班写了个电子考勤系统!室友为啥孤立我了?

    前言 今天美女导师突然找到我,我还以为要找我来一场师生恋呢.原来是她不知道从哪里听到我会一些编程语言,就过来问我能不能写一个电子考勤系统,就像上班要打卡一样,比如八点上课,十点下课,那就八点打上课卡, ...

  6. 用Python编写一个电子考勤系统

    实验项目简介 学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应用开发语言Python,准备让你们实现部分学生端考勤功能.经过和老师的沟通,你了解到: (1) 目前该系统已经被学长实现了部 ...

  7. 企业考勤管理系统python_用Python编写一个电子考勤系统!谁还敢迟到?

    学校现在需要实现一个电子考勤系统,考虑到你们班已经学过大数据应用开发语言Python,准备让你们实现部分学生端考勤功能.经过和老师的沟通,你了解到: (1) 目前该系统已经被学长实现了部分功能,你们只 ...

  8. python股票全套系统_熬了一晚上,小白用Python写了一个股票提醒系统

    码农小马七夕节去相亲了,见了一个不错的姑娘,长的很是甜美!聊着聊着很投缘!通过介绍人了解到,对方也很满意--想着自己单身多年的生活就要结束啦,心里满是欢喜,美美哒!可是突然想起年初还有几万块在股市里面 ...

  9. python写一个系统-熬了一晚上,小白用Python写了一个股票提醒系统

    码农小马七夕节去相亲了,见了一个不错的姑娘,长的非常甜美!聊着聊着很投缘!通过介绍人了解到,对方也很满意--想着自己单身多年的生活就要结束啦,心里满是欢喜,美美哒!但是突然想起年初还有几万块在股市里面 ...

最新文章

  1. Only the original thread that created a view hierarchy can touch its views.
  2. flask + react_再写一本 Flask 书
  3. tensorflow系列之1:加载数据
  4. protected default
  5. c malloc 头文件_C/C++求职者必备 23 道面试题,一道试题一份信心!
  6. 输入输出(I/O)流。
  7. erlang四大behaviour之四-supervisor(转载)
  8. noip2017提高组初赛c语言,NOIP2017提高组比赛体验篇一(干货)
  9. 亚马逊卖家培训返校季爆单技巧
  10. matlab幻方置乱,幻方置乱,magic scrambling,音标,读音,翻译,英文例句,英语词典
  11. cdr宏教程_cdr软件怎么使用宏批量导出文件?
  12. 角谷猜想:所谓角谷猜想,是指对于任意一个正整数,如果是奇数,则乘 3 加 1,如果是偶数,则除以2,得到的结果再按照上述规则重复处理,最终总能够得到 1。如假定初始整数为 5,计算过程分别为 16、
  13. 莱鸟学spss数据分析之第六章---描述性分析
  14. H5及微信小程序实测可用——监听手机返回键操作
  15. 解决小程序-wx.canvasGetImageData()-RGB取色盘苹果手机获取颜色慢问题
  16. Day8——反转字符串、反转字符串||、替换空格、反转字符串里的单词、左旋字符串
  17. Autonomous automobile trajectory tracking for off-road driving翻译学习
  18. 【游记】NOIP2015造纸记
  19. 帕斯卡三角形 (Pascal)
  20. 学习日记day27 平面设计 构图

热门文章

  1. echarts图标数据较多文字较长缩放重叠问题的配置
  2. postgres导入excel_PostgreSQL导入Execl表格方法
  3. 244页14万字XX智能交通系统设计方案
  4. 技能高考c语言经典试题及答案,技能练习题
  5. 如何简单地理解泊松分布
  6. OkHttp(二)—— 拦截器
  7. 【Java综合专栏】「引领序幕」全链路追踪原理之Java Agent探针的技术介绍(上篇)
  8. 图文介绍——NC使用笔记
  9. 【总结】解决Linux机器重装后-免密登录报错问题
  10. System Repair Engineer 2.6 (2.6.12.1018)