学生信息管理系统

一、系统指南

本系统为表格式的学生信息管理系统,提供了文件新建、打开及保存功能,还可在表格中对数据进行增加、删除、修改、搜索,下面将一一介绍这些功能

1、新建文件

新建文件将会产生一个全新的空表格,在新建文件时,当前表格的内容将会被删除,系统会自动检测当前表格内容是否已经被保存过,如果未保存过的,会对用户进行提示;否则将直接生成新表格

2、打开文件

系统可以打开由系统保存的、符合系统规范的.csv文件。

3、保存文件

系统将当前表格保存为.csv文件。之所以保存为.csv文件,除了考虑到这种文件具有非常规整的模式之外,还考虑到该格式可使用微软excel表格打开,便于实际场景中的使用。

4、增加

在系统菜单栏编辑项中和系统右键菜单中,有三种方式对表格数据进行增加,分别是“增加一行”,“上方插入一行”和“下方插入一行”。

点击“增加一行”,会在表格末尾生成一行空行。

点击“上方插入一行”,会在当前选中表格的上方插入一行空行。

点击“下方插入一行”,会在当前选中表格的下方插入一行空行。

5、删除

在系统菜单栏编辑项中和系统右键菜单中,提供了“删除”选项。

点击删除选项之后,当前选中的行会被删除掉。

6、修改

双击表项即可进入编辑模式,对表格内容进行编辑。其中性别、专业和出生日期栏还提供了下拉选择项,便于使用者对其进行编辑。

7、搜索

系统工具栏中有一个搜索文本框,用户只需要在框中输入搜索内容,之后点击窗口右边的“搜索”按钮即可进行搜索。除了搜索按钮以外,还有“上一个”和“下一个”按钮,用以继续查询。

8、排序

若要按照某个属性进行排序,只需要双击该属性表头即可。首次点击按照字符正序按该列对表格进行扩展排序,再次点击进行倒序排序,再次点击又变为正序排序,以此类推。搜索仅支持精确搜索,不支持模糊搜索。

二、系统实现

本系统主要由三个继承类构成,一个是MianWindow类,它继承自QMainWindow类,是系统的主要部分,另外两个类为Delegate和DateDelegate类,它们都继承自QItemDelegate类,用以实现表项中的下拉选项,前者实现了性别和专业方向下拉选项,后者实现了出生日期的下拉选项。

MainWindow类中还集成了QAction类、QWidget类、QLayout类、QTableWidget类、QLineEdit类、QPushButton类、QString类。**请注意,系统中出现的其他Qt类,以及dialog.cpp、student.cpp、studentdatabase.cpp和他们对应的头文件中封装的类,仅为系统实现过程中的遗产代码,在系统中不发挥作用,仅为日后留作他用。**其实就是懒得删掉。

1、MainWindow类

MainWindow类属性和接口定义如下

class MainWindow : public QMainWindow

{

Q_OBJECT

public:

explicit MainWindow(QWidget *parent = 0);

~MainWindow();

protected:

void closeEvent(QCloseEvent *event);

private:

Ui::MainWindow *ui;

//文件保存标识符

bool saved;

QWidget *widget;

//布局管理器

QLayout *layout;

//表格及其初始化函数

QTableWidget *table;

void tableInitialize();

//菜单栏选项

QAction *newAction;

QAction *openAction;

QAction *saveAction;

QAction *exitAction;

QAction *addAction;

QAction *deleteAction;

QAction *moveUpAction;

QAction *moveDownAction;

QAction *insertAction;

//排序辅助数组。用于实现对某属性的第奇数次为正排,偶数次为倒排

bool c[8];

//储存有表格下拉选项的QComboBox

QVector *QComboBoxList;

//工具栏搜索的文本框、三个按钮和搜索关键词

QLineEdit *searchQLineEditToolBar;

QPushButton *searchButton;

QPushButton *lastButton;

QPushButton *nextButton;

//搜索文本

QString searchQstr;

//当前搜索到的表格位置

int searchRow;

int searchColumn;

//快速排序,按照字符串比较顺序

int partition(int p, int q, int column);

void quickSort(int p, int q, int column);

void Swap(int p1,int p2, int column);

//表项右键菜单

virtual void contextMenuEvent(QContextMenuEvent *event);

private slots:

//响应函数们

//新建文件

void newFile();

//打开文件

void openFile();

//保存文件

void saveFile();

//表格末尾增加一行

void addModify();

//菜单栏中的删除当前行

void deleteModify();

//菜单栏中的当前行上移一行

void moveUpModify();

//菜单栏中的当前行下移一行

void moveDownModify();

//按照选定属性进行排序

//参数是选定属性所在列的索引

void sortView(int colunmIndex);

//表格修改

//表格修改后,将saved改为false,标识文件未保存

void tableModify(int row,int column);

//在当前行上一行插入空行

void insertBefore();

//在当前行下一行插入空行

void insertAfter();

//右键菜单中的删除当前行

//实际上与菜单栏中的删除当前行响应函数(void deleteModify())没有区别

void deleteLine();

//搜索文本获取

//每当搜索文本框中内容改变时,调用该函数对搜索文本searchQstr进行赋值

void searchQlineEditChanged(QString qstr);

//搜索按钮响应函数

//执行搜索,搜出第一个符合的位置并选中高亮。搜不到的话表格不会有任何变化。

void searchToolBarTriggered();

//搜索上一个

void lastToolBarTriggered();

//搜索下一个

void nextToolBarTriggered();

};

2、Delegate类

Delegate类继承自QDelegate类,用以实现的性别和专业自定义委托。Delegate类属性和接口定义如下

class Delegate : public QItemDelegate

{

Q_OBJECT

public:

Delegate(QObject *parent = nullptr);

~Delegate();

//绘制下拉选项菜单

void paint(QPainter *painter, const QStyleOptionViewItem &option,

const QModelIndex &index) const;

//下拉选项大小

QSize sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const;

//创建自定义按钮

QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const;

//设置自定义按钮内容

void setEditorData(QWidget *editor, const QModelIndex &index) const;

void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const;

private:

};

3、DateDelegate类

DateDelegate类也继承自QDelegate类,用以实现出生日期的自定义委托,DateDelegate类属性和接口定义如下

class DateDelegate : public QItemDelegate

{

Q_OBJECT

public:

DateDelegate(QObject *parent = nullptr);

~DateDelegate();

//返回改变Model数据的widget,该widget是经过定制行为的Widget

QWidget *createEditor(QWidget * parent, const QStyleOptionViewItem & option, const QModelIndex & index) const;

//将可操作的数据提供给widget

void setEditorData(QWidget * editor, const QModelIndex & index) const;

//将widget的数据展示到Item中

void setModelData(QWidget * editor, QAbstractItemModel * model, const QModelIndex & index) const;

//确保widget能够正确显示到view中

void updateEditorGeometry(QWidget * editor, const QStyleOptionViewItem & option, const QModelIndex & index) const;

private:

};

Linux学生QT成绩查询系统大作业报告,GitHub - cxc1357/Student-Information-Manage-System: QT实现的学生信息管理系统,高程大作业...相关推荐

  1. 基于区块链的学生课程成绩查询系统

    基于区块链的学生课程成绩查询系统 [摘 要]传统成绩管理系统存在数据易窜改的问题.本文根据区块链不可窜改的原理设 计并实现课程成绩查询系统.系统基于以太坊技术开发,采用 Node.js 作为服务器后端 ...

  2. asp毕业设计——基于asp+access的学生成绩查询系统设计与实现(毕业论文+程序源码)——成绩查询系统

    基于asp+access的学生成绩查询系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于asp+access的学生成绩查询系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦. ...

  3. 学生成绩查询java版_学生成绩查询系统,基于ssm的JAVA系统

    每天记录学习,每天会有好心情.*^_^* 今天记录的项目是学生成绩查询系统,这个项目是这么回事:介绍了在Internet/WWW环境下构建学生成绩查询系统的设计思路与方法 ,阐述了在学生成绩查询系统中 ...

  4. c语言学生成绩查询课设报告,C语言课设报告(学生考试成绩查询程序)【荐】.doc...

    C语言课设报告(学生考试成绩查询程序)[荐].doc 学生考试成绩查询程序 学号:******** 姓名:***** 完成日期:****年月 通过键盘输入学生的考试信息,包括:学号.姓名.课程名称.学 ...

  5. 威海市计算机成绩查询,2020年山东威海小升初成绩查询系统平台:http://jyj.weihai.gov.cn/...

    [导语]2020年山东威海小升初成绩查询入口开通后,考生可登录威海市教育局小升初服务平台或点击下面链接进入山东威海小升初成绩查询系统.具体如下: 山东威海小升初考试成绩出来后一般由学校统一负责通知,学 ...

  6. c语言作业查询,C语言大作业学生成绩查询系统源代码.doc

    C语言大作业学生成绩查询系统源代码 #include #include struct student { char name[20]; char speciality[10]; int C; int ...

  7. c语言成绩查询系统大作业,C语言 · 成绩查询系统(示例代码)

    抱歉,昨天忘了往博客上更新,今天补上. 成绩查询系统 分值: 21 数学老师小y 想写一个成绩查询系统,包含如下指令: insert [name] [score],向系统中插入一条信息,表示名字为na ...

  8. 学生成绩查询系统(Java实现),你第一个Java小项目

    一.学生成绩查询系统(Java实现) 项目要求(我们可以做的更面向对象一点,灵活处理): 具体思路如下: 1.引入程序需要调用的包 2.创建总程序包 "stuScoreInquirySyst ...

  9. android学生成绩查询代码,android学生成绩查询系统.pdf

    android学生成绩查询系统 嵌入式系统课程设计报告 学生成绩查询系统手机端 I 摘要 在 世纪的今天,互联网已深入世界的各个角落.而WAP技术的发展和无线业务的成 21 熟,为人们获取各种信息提供 ...

最新文章

  1. 超详细单机版搭建hadoop环境图文解析
  2. 列举一些RNN类模型的常见使用形式以及常见的应用
  3. mysql5.7版本源_用最新MySQL 8.0的源安裝MySQL 5.7版本(CentOS 7環境下)
  4. mysql pgsql 2017,DB-Engines 2017 年度数据库:PostgreSQL 实至名归
  5. 刚刚,阿里开源了一项重磅炸弹,终结程序员“中年危机”!
  6. mysql 同一天多条记录只取第一条_MySQL面试高频100问(二)
  7. 浅析MySQL存储引擎序列属性
  8. JAVA内存模型和GC原理
  9. JavaWeb请求的重定向与转发:getRequestDispatcher()的forward方法,sendRedirect方法,以及重定向与转发的区别
  10. 高级软考之——系统分析师思维导图(一)
  11. EasyRecovery注册码哪里有?
  12. HTML网页实训的目的,web前端设计与开发-实验目的及要求 (2)
  13. eNSP vlan 划分实验
  14. Google Chrome插件开发-Context Menus
  15. P1234 小A的口头禅题解
  16. lr_用java_Vuser做性能测试
  17. Laravel Carbon
  18. 快速上手opencv_contrib安装(Windows11)
  19. C++编程练习——五子棋游戏
  20. 职称申报一年比一年难

热门文章

  1. 用java实现建造者模式
  2. 【创建Vue手脚架项目】
  3. 物联网卡就是不能打电话的电话卡?
  4. 【小罗的hdlbits刷题笔记5】基于fifo思想的fsm设计(Exams/2014 q3fsm)
  5. MCDF中arbiter的轮询机制
  6. 求矩阵的特征根和特征向量
  7. SQLSTATE[HY000] [1049] Unknown database
  8. MPII数据集下载缓慢
  9. 斗地主Java课程设计_Java斗地主发牌课程设计
  10. maven打包时打包指定的lib文件夹