莞工勤工俭学自动考勤助手
Created on February 14, 2021 by Bertram for students of Dongguan University of Technology
Auto_Attendance实现莞工学工系统勤工俭学岗位自动打卡的功能,适用于各学生助理、助理班主任等勤工俭学职位的日常考勤打卡。用以实现自动考勤,避免忘记打卡和打了卡但忘记签退等因“忘记”而引发的情况。
由于定时任务太多,Github Actions会创建一个执行队列,因此经常会出现定时任务不在指定时间运行的情况,往往会有几分钟到几十分钟不等的延迟,尤其是在UTC16:00(即北京时间0:00)前后。此外,GitHub Actions本身的保护机制使得单个程序最大运行时间是360分钟。因此,为保证其稳定性,程序定时每天7:30和13:30启动,然后在python程序中设置简单的循环进行监控,在需要签到和签退的时刻运行签到和签退操作。除了可以设置个人的考勤时间外,还能设置是否在休息日(包括法定节假日)是否考勤。
- Python3.7
- Github Actions
- 网络爬虫(主要是requests和解析库的使用)
- 配置文件的基本知识
| 需要添加的repository secret | 含义 | 例 |
|---|---|---|
| USERNAME | DGUT中央认证系统账号 | 20184141xxxx |
| PASSWORD | 密码 | 123456 |
设置考勤时间不需要编辑python代码,仅需要编辑schedule.json文件
在schedule.json文件中,"0"-"6"表示星期日-星期六(每周的第一天是星期日),其映射的列表表示考勤时间
考勤时间列表的每一个元素亦是一个列表,代表一次考勤的开始时间和结束时间,下面这个例子能让你更加清楚如何制定自己的考勤时间表Tips: 不要更改schedule.json的文件结构;时间要严格按照"时:分"的格式,不要精确到秒。否则将造成程序无法正常运行
schedule.json
{
"0": [
],
"1": [
["8:30", "10:10"],
["14:30", "17:30"]
],
"2": [
["8:30", "12:00"]
],
"3": [
["14:30", "17:30"]
],
"4": [
["8:30", "10:10"]
],
"5": [
["14:30", "17:00"]
],
"6": [
]
}
上面这段json代码的意思是:
| 星期 | 考勤时间 |
|---|---|
| 星期日 | - |
| 星期一 | 8:30-10:10 14:30-17:30 |
| 星期二 | 8:30-12:00 |
| 星期三 | 14:30-17:30 |
| 星期四 | 8:30-10:10 |
| 星期五 | 14:30-17:30 |
| 星期六 | - |
按照自己的需求设置即可,下面我们来对schedule.json进行在线编辑
config.ini一般不需要进行配置。该文件下有两个参数:
- holiday_attendance: bool类型,设置休息日及法定节假日是否考勤,True则考勤,False则不考勤,默认为False
- workAssignmentId: int类型,设置考勤职位的ID,当你有2个职位的时候可能会用到该参数
如果有多个职位,需要指定具体某一个职位;或者想要提高运行效率,可以配置一下workAssignmentId
以下是配置方法。若无需配置,跳到下一节
首先登录学工系统,来到考勤页面,并按F12打开开发者工具
假设网安学院学生工作助理的workAssignmentId=9200。那么,config.ini文件应该这么写
[attendance]
holiday_attendance = False
workAssignmentId = 9200
文件在线配置的方法可参考2.3. 设置考勤时间
Auto_Attendance
│ attendance.py
│ config.ini
│ README.md
│ requirements.txt
│ schedule.json
│
├─.github
│ └─workflows
│ main.yml
│
└─Dgut
DgutLogin.py
DgutXgxtt.py
__init__.py
错误类型的说明.png
- attendance.py: 主程序
- config.ini: 关于休息日是否考勤、考勤职位ID等信息的配置文件
- README.md: 项目说明
- requirements.txt: 运行程序所需的python第三方库及使用版本
- schedule.json: 考勤时间配置文件
- .github/workflows/main.yml: YAML文件,创建github action的工作流workflows
- Dgut: 作者编写的用于莞工账号模拟登录和相关系统进行爬虫操作的库
Github Actions经常性不会准时开启定时任务,通常延迟几分钟到几十分钟才运行,因此程序设置了7:30和13:30的定时任务(因为GitHub Actions限制每个程序只能运行6个小时,因此分两次运行),在程序上设置时间监控进行考勤
账号和密码是使用Github Actions Secrets保存,安全性由Github及其安全算法来保障。不能说万无一失,只能说安全性还是有保障的。如果你有一台一直在运行的电脑,直接本地运行会更具安全性,但相应地也失去便捷性
- 有需求或技术方面的问题请联系作者Email:3233406405@qq.com
















