Compare commits
4 Commits
v0.0.1-bet
...
main
Author | SHA1 | Date | |
---|---|---|---|
12334c1444 | |||
|
80f7476eeb | ||
5dfbb0ae8a | |||
|
b9cc46b2cf |
51
README.md
51
README.md
@ -1,21 +1,32 @@
|
||||
# Student Manager
|
||||
## 介绍
|
||||
### 前言
|
||||
### <font color=FFA500>最新版本:</font>[![releases](https://badgen.net/github/release/WisdomTech-Studio/Student-Manager)](https://github.com/WisdomTech-Studio/Student-Manager/releases)
|
||||
|
||||
## <font color=1E90FF>前言</font>
|
||||
这是一个极其简单且简陋的Python项目,是工作室成员用来练习Python的。
|
||||
**因此不要将此程序用于管理学生!**(~~也没人看的上~~)
|
||||
开发者们都是**新手**,如果有任何方面的错误请指正
|
||||
### 运行
|
||||
项目其中有两个.py文件,分别是**main.py**和**gui.py**,二者运行其中一个皆可。 它们的区别在于:
|
||||
* **main.py是在终端上显示输出结果并与用户交互;**
|
||||
* **而gui.py则会显示独立窗口与用户交互。**
|
||||
**<font color=8B0000>因此不要将此程序用于管理学生!</font>**<font color=A9A9A9>(~~也没人看的上~~)</font>
|
||||
开发者们都是**新手**,如果有任何方面的意见或建议请向我们提出!
|
||||
## <font color=1E90FF>需要的第三方库</font>
|
||||
**gui.py**需要第三方库<u>[ttkbootstrap](https://ttkbootstrap.readthedocs.io/en/latest/zh/gettingstarted/installation/)</u>。
|
||||
|
||||
       <font color=8470FF>**通过PyPI安装**</font>
|
||||
```
|
||||
python -m pip install ttkbootstrap
|
||||
```
|
||||
     <font color=8470FF>**通过PyPI清华镜像源安装**</font>
|
||||
```
|
||||
python -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple ttkbootstrap
|
||||
```
|
||||
## <font color=1E90FF>运行</font>
|
||||
项目其中有两个.py文件,分别是**main.py**和**gui.py**,二者运行其中一个皆可。 它们的区别在于:
|
||||
* <font color=FFA500>**main.py是在终端上显示输出结果并与用户交互;**</font>
|
||||
* <font color=FFA500>**而gui.py则会显示独立窗口与用户交互。**</font>
|
||||
|
||||
因此我们建议运行**gui.py**,体验更佳
|
||||
### **<u>!!!注意!!!由于main.py中使用了“f字符串”,故仅适用于Python3.6及以上的Python版本运行!</u>**
|
||||
***
|
||||
### 代码简述
|
||||
***
|
||||
#### main.py
|
||||
**主要开发者:** [Billts-noo](https://github.com/Billts-noo)
|
||||
### **<font color=8B0000><u>!!!注意!!!由于main.py中使用了“f字符串”,故仅适用于Python3.6及以上的Python版本运行!</u></font>**
|
||||
## <font color=1E90FF>代码简述</font>
|
||||
|
||||
### <font color=8470FF>**main.py**</font>
|
||||
**主要开发者:** <u>[Billts-noo](https://github.com/Billts-noo)</u>
|
||||
**运行原理(单独运行main.py时):**
|
||||
1. 使用`print()`函数输出指定菜单,并标注各功能所对应的数字,用户通过在终端输入数字使用对应功能;
|
||||
|
||||
@ -30,14 +41,14 @@ def add_student(name, gender):
|
||||
```
|
||||
3. 在删除、查找以及后续会上线的更改功能中,我们都在对学生信息操作前遍历一次列表**stu_names_list**比对被操作的学生是否存在,再根据结果执行对应操作;
|
||||
|
||||
4. 我们还使用pickle模块实现了**数据存储**的功能,**students info.json**和**students names.json**分别存储两个列表**stu_info_list**和**stu_names_list**,第一次保存时会自动创建。**<u>用户需要执行在主菜单的操作“保存并退出”才能正常保存数据!</u>**
|
||||
5. **functions.py**将管理系统要用到的函数独立出来,为了函数能正常调用上述的两个列表,我们使用自定义函数`share_lists()`实现两个文件之间的列表传输。*(想法来自于工作室成员xnz233)*
|
||||
4. 我们还使用pickle模块实现了**数据存储**的功能,**students info.json**和**students names.json**分别存储两个列表**stu_info_list**和**stu_names_list**,第一次保存时会自动创建。**<font color=8B0000><u>用户需要执行在主菜单的操作“保存并退出”才能正常保存数据!</u></font>**
|
||||
5. **functions.py**将管理系统要用到的函数独立出来,为了函数能正常调用上述的两个列表,我们使用自定义函数`share_lists()`实现两个文件之间的列表传输。<font color=A9A9A9>*(想法来自于工作室成员xnz233)*</font>
|
||||
***
|
||||
#### gui.py
|
||||
**主要开发者:** [xnz233](https://github.com/xnz233/)
|
||||
### <font color=8470FF>**gui.py**</font>
|
||||
**主要开发者:** <u>[xnz233](https://github.com/xnz233/)</u>
|
||||
**运行原理(单独运行gui.py时):**
|
||||
1. 使用`tkinter`库进行窗口的绘制,并与主程序共用一部分函数;自定义了窗口的类,将图形界面部分的定义单独抽离出来,使得代码逻辑更加清晰,下面是部分代码:
|
||||
```python
|
||||
```Python
|
||||
class StudentManagementGUI:
|
||||
def __init__(self, root):
|
||||
global screen_height, screen_width, root_width, root_height
|
||||
@ -55,4 +66,4 @@ f"{root_width}x{root_height}+{int((screen_width-root_width)/2)}+{int((screen_hei
|
||||
# more...
|
||||
```
|
||||
|
||||
2. 使用`ttkbootstrap`库进行窗口美化,使图形化窗口更美观。
|
||||
2. 使用<u>[ttkbootstrap](https://ttkbootstrap.readthedocs.io/en/latest/zh/gettingstarted/installation/)</u>库进行窗口美化,使图形化窗口更美观。
|
||||
|
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue
Block a user