10.11每日作业

news2024/10/12 0:45:25

数据表

#include "widget.h"
#include "ui_widget.h"


Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //想要添加某个数据库
    if(!db.contains("stu.db"))
    {
        //如果当前对象中没有包含所需数据库,则添加一个数据库
        db = QSqlDatabase::addDatabase("QSQLITE");   //添加一个sqlite3的数据库
        db.setDatabaseName("stu.db");                //设置数据库名称
    }

    //打开数据库
    if(!db.open())
    {
        QMessageBox::information(this,"提示","数据库打开失败");
        return;
    }

    //程序执行至此,表示数据库创建成功并打开了
    //准备创建数据表
    //1、实例化一个sql语句的执行者
    QSqlQuery querry;
    //2、准备sql语句
    QString sql = "create table if not exists STU(id int, name char, sex char ,score double);";
    //3、执行sql语句
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"提示","数据表创建失败");
        return;
    }
    //程序执行至此,表示数据表也创建成功了

}

Widget::~Widget()
{
    delete ui;
}

//添加信息按钮对应的槽函数
void Widget::on_addBtn_clicked()
{
    //1、将ui界面上的相关信息获取下来
    int ui_numb = ui->numbEdit->text().toUInt();
    QString ui_name = ui->nameEdit->text();
    QString ui_sex = ui->sexEdit->text();
    double ui_score = ui->scoreEdit->text().toDouble();

    //2、判断信息中是否有空的
    if(ui_numb == 0 || ui_name.isEmpty() || ui_sex.isEmpty() || ui_score == 0)
    {
        QMessageBox::information(this,"提示","请将信息填写完整");
        return;
    }

    //3、准备sql语句
    QString sql = QString("insert into STU(id,name,sex,score) values(%1 , '%2' , '%3' , %4);").arg(ui_numb).arg(ui_name).arg(ui_sex).arg(ui_score);

    //qDebug() << sql;
    QSqlQuery querry;
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"提示","添加信息失败");
        return;
    }
    else
    {
        QMessageBox::information(this,"提示","添加成功");
    }

}






void Widget::on_showBtn_clicked()
{

    //1、实例化一个sql语句执行者
    QSqlQuery querry;

    //2、准备sql语句
    QString sql = "select * from STU;";

    //3、执行sql语句
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"提示","查询失败");
        return;
    }

    //程序执行至此,表示已经完成数据库的查询,并将结果存放到querry对象中,可以通过next函数遍历每个结果集
    //函数原型:bool next();
    int i = 0;
    while(querry.next())
    {
        QSqlRecord record = querry.record();

        for(int j = 0;j<record.count();j++)
        {
            //record.value(j).toString();
            //ui->msgTable->setItem(i,j,new QTableWidgetItem(record.value(j).toString()));
            QTableWidgetItem *item = new QTableWidgetItem(record.value(j).toString());
            ui->msgTable->setItem(i,j,item);
        }
        i++;
    }






}

void Widget::on_deleteBtn_clicked()
{
    // 1、将ui界面上的相关信息获取下来
    QString ui_name = ui->nameEdit->text();

    // 2、判断姓名是否为空
    if(ui_name.isEmpty())
    {
        QMessageBox::information(this,"提示","请输入姓名以删除记录");
        return;
    }

    // 3、准备sql语句
    QString sql = QString("delete from STU where name = '%1';").arg(ui_name);

    // qDebug() << sql;
    QSqlQuery querry;
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"提示","删除信息失败");
        return;
    }
    else
    {
        QMessageBox::information(this,"提示","删除成功");
    }

    // 4、更新表格以反映删除后的数据
    // 清空表格
    ui->msgTable->setRowCount(0);
    // 5、重新查询并显示最新数据
    QString selectSql = "select * from STU;";
    if(!querry.exec(selectSql))
    {
        QMessageBox::information(this,"提示","查询失败");
        return;
    }

    int i = 0;
    while(querry.next())
    {
        QSqlRecord record = querry.record();
        ui->msgTable->insertRow(i); // 插入新行

        for(int j = 0; j < record.count(); j++)
        {
            QTableWidgetItem *item = new QTableWidgetItem(record.value(j).toString());
            ui->msgTable->setItem(i, j, item);
        }
        i++;
    }

}

void Widget::on_sortBtn_clicked()
{

    // 1、实例化一个sql语句执行者
    QSqlQuery querry;

    // 2、准备sql语句,按score排序
    QString sql = "select * from STU order by score;";

    // 3、执行sql语句
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"提示","查询失败");
        return;
    }

    // 清空表格
    ui->msgTable->setRowCount(0);

    // 4、遍历查询结果并显示在msgTable中
    int i = 0;
    while(querry.next())
    {
        QSqlRecord record = querry.record();
        ui->msgTable->insertRow(i); // 插入新行

        for(int j = 0; j < record.count(); j++)
        {
            QTableWidgetItem *item = new QTableWidgetItem(record.value(j).toString());
            ui->msgTable->setItem(i, j, item);
        }
        i++;
    }
}

人脸识别

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    VideoCapture video;

//    if(!video.open("D:\\opencv\\resourse\\01.mp4"))
//    {
//        QMessageBox::information(this,"提示","视频文件打开失败");
//        return;
//    }
    //打开本机摄像头
    if(!video.open("D:\\opencv\\resourse\\01.mp4"))
    {
        QMessageBox::information(this,"提示","视频文件打开失败");
        return;
    }

    Mat src;
    Mat gray;
    Mat dest;

    CascadeClassifier c;
    vector<Rect> faces;

    if(!c.load("D:\\opencv\\resourse\\haarcascade_frontalface_alt.xml"))
    {
        QMessageBox::information(this,"提示","级联分类器加载失败");
        return;
    }


    while(video.read(src))
    {

        cv::flip(src,src,1);

        cv::cvtColor(src,gray,CV_BGR2GRAY);

        cv::equalizeHist(gray,dest);

        /*
        for(int i = 0;i<src.rows;i++)
        {
            for(int j = 0;j<src.cols;j++)
            {
                for(int k = 0;k<3;k++)
                {
                    src.at<cv::Vec3b>(i,j)[k] = 255-src.at<cv::Vec3b>(i,j)[k];
                }
            }
        }*/

        c.detectMultiScale(dest,faces);
        for(int i = 0;i<faces.size();i++)
        {
            cv::rectangle(src,faces[i],Scalar(0,0,255),2);
            cv::rectangle(gray,faces[i],Scalar(0,0,255),2);
            cv::rectangle(dest,faces[i],Scalar(0,0,255),2);
        }



        imshow("src",src);
        imshow("gray",gray);
        imshow("dest",dest);
        if(waitKey(30) ==27)
        {
            break;
        }
    }

}

Widget::~Widget()
{
    delete ui;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2206393.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

dowhy中反驳实验怎么做?

首先&#xff0c;我们打开最新的dowhy版本网站。 https://www.pywhy.org/dowhy/v0.11.1/index.html 我们主要看标题栏的User Guide和Examples就可以了&#xff0c;如果在User Guide 里找不到使用方法&#xff0c;就去Examples里找例子&#xff0c;里面的数据读取修改为自己的数…

HI6338 (DIP-8内置75W方案)

Hi6338 combines a dedicated current mode PWM controller with integrated high voltage power MOSFET.Vcc low startup current and low operating current contribute to a reliable power on startup design with Hi6338. the IC operates in Extended ‘burst mode’ to …

前端的全栈混合之路Meteor篇:分布式数据协议DDP深度剖析

本文属于进阶篇&#xff0c;并不是太适合新人阅读&#xff0c;但纯粹的学习还是可以的&#xff0c;因为后续会实现很多个ddp的版本用于web端、nodejs端、安卓端和ios端&#xff0c;提前预习和复习下。ddp协议是一个C/S架构的协议&#xff0c;但是客户端也同时可以是服务端。 什…

Java程序打包成jar包

步骤1 打开项目结构 步骤2 配置工件 选择你要打包的模块选择主类(程序的主入口main类)提取到目标会把库文件的jar包打包到目标,一般选择这个,更方便在不同电脑上运行 步骤3 构建并生成jar包 最后,在对应的out/artifacts文件夹中找到jar包,在终端输入java -jar xxxx.jar就可以正…

mac电脑如何删除应用程序?怎么删除苹果电脑里的软件

在使用Mac电脑的过程中&#xff0c;随着时间的推移&#xff0c;我们可能会安装大量的应用程序。然而&#xff0c;这些应用程序中有很多可能只是临时使用&#xff0c;或者已经不再需要了。这些无用的应用程序不仅占据了宝贵的硬盘空间&#xff0c;还可能拖慢Mac系统的运行速度。…

JAVA基础 day12

一、File、IO流 File是java.io.包下的类&#xff0c;file类的对象&#xff0c;用于代表当前操作系统的文件&#xff08;可以代表文件、文件夹&#xff09;&#xff0c;使用File可以操作文件及文件夹。 注意&#xff1a;File只能对文件本身进行操作&#xff0c;不能读写文件里…

Vivado工程如何生成TCL文件以及如何利用TCL文件还原工程

Vivado工程如何生成TCL以及如何利用TCL还原工程 一、Vivado工程如何生成TCL文件一、利用TCL文件还原Vivado工程 为了方便Vivado工程的保存和传输&#xff0c;尤其是功能复杂的工程&#xff0c;其工程容量越大&#xff0c;因此&#xff0c;为了能够保留工程功能的同时&#xff0…

No.15 笔记 | CSRF 跨站请求伪造

目录 一、基础知识 &#xff08;一&#xff09;cookie 和 session、同源策略 &#xff08;二&#xff09;CSRF 原理 二、CSRF 类型 &#xff08;一&#xff09;GET 类型 &#xff08;二&#xff09;POST 类型 三、CSRF 实例讲解 &#xff08;一&#xff09;真实案例 &am…

消防应急物资仓库管理系统

集驰电子消防装备仓库管理系统(DW-S302系统)是一套成熟系统&#xff0c;依托3D技术、大数据、RFID技术、数据库技术、对装备器材进行统一管理&#xff0c;以RFID射频识别技术为核心&#xff0c;构建以物资综合管理为基础&#xff0c;智能分析定位为主要特色功能的装备器材库综合…

EtherNet IP网关HT3S-EIS-MDN读取七星华创CS310空气流量计数据应用案例

七星华创流量计CS310 (MODBUS RTU系列) 通过EtherNet/IP网关HT3S-EIS-MDN 与汇川H5U-A8的PLC进行交换数据应用案例 一、概述 本文主要介绍使用HI-TOP网关 HT3S-EIS-MDN在汇川H5U-A8 PLC和七星华创CS310流量计之间进行数据交换。 解决的问题&#xff1a;汇川H5U-A8如何通过…

机器学习篇-day05-ID3决策树 C4.5决策树 CART决策树-回归决策树 剪枝

一. 决策树简介 主要用于分类 概述 简介 概念 决策树是一种树形结构&#xff0c;树中每个内部节点表示一个特征上的判断&#xff0c;每个分支代表一个判断结果的输出&#xff0c;每个叶子节点代表一种分类结果, 根节点尤为重要. 构建决策树步骤 特征选择&#xff1a;选取有较…

java医院后台管理系统设计与实现源码(springboot+vue+mysql)

项目简介 医院后台管理系统设计与实现实现了以下功能&#xff1a; 管理员&#xff1a;首页、个人中心、用户管理、零食分类管理、零食信息管理、订单评价管理、系统管理、订单管理。 用户&#xff1a;首页、个人中心、订单评价管理、我的收藏管理、订单管理。 前台首页&…

精选算法入门——day3

精选算法入门——day3 题目一题干解题思路一代码解题思路二代码解题思路三代码 题目二题干解题思路 题目三题干解题思路 题目四题干解题思路一代码解题思路二 题目五题干解题思路一代码解题思路二代码&#xff1a; 题目一 题干 大家都知道斐波那契数列&#xff0c;现在要求输…

尚雷仕(湖北)健康科技公司5.98MW分布式光伏10KV并网系统应用

1.概述 我国正致力于实现“双碳”目标&#xff0c;新能源装机容量正快速增长&#xff0c;电力系统正在经历向高比例新能源系统的转型。然而&#xff0c;分布式光伏的接入也带来了挑战&#xff0c;例如电能质量的下降和供电可靠性的不足。尽管如此&#xff0c;光伏发电依然具有…

Java的IO操作与文件的基本常识

首先什么是IO操作呢? IO操作其实解释操作硬盘 1. 文件系统操作 创建文件,删除文件,重命名文件,创建目录…操作 2. 文件内容操作 进行读与写操作 先来了解一下基本的文件知识方便学习接下来的IO操作 文件路径 文件路径是从数根节点触发,沿着树杈一直往下走,到达目标文件…

github——指标统计

github——指标统计 它的作用特定项目统计首页展示 github-readme-stats是一个可以统计指定用户github指标的项目。可以使用此项目统计自己的github&#xff0c;用于首页展示。效果如图&#xff1a; 它的作用 它可以&#xff1a; 统计git操作统计账户编程语言构成比例解除githu…

ThingsBoard规则链节点:Delete Keys节点详解

引言 删除键节点简介 用法 含义 应用场景 实际项目运用示例 智能家居系统 工业自动化生产线 车联网平台 结论 引言 ThingsBoard是一个功能丰富的物联网平台&#xff0c;它支持设备管理、数据收集与处理以及实时监控。其核心组件之一是规则引擎&#xff0c;允许用户定义…

杨中科 ASP.NETCORE 异步编程二

一、不要用sleep() 如果想在异步方法中暂停一段时间&#xff0c;不要用Thread.sleep()&#xff0c;因为它会阻塞调用线程&#xff0c;而要用await.Task.Delay()。 举例: 下载一个网址,3秒后下载另一个 示例&#xff1a; sleep() 为了能直观看到效果&#xff0c;使用winfor…

基于springboot vue 三味书屋网络书店销售管理设计与实现

博主介绍&#xff1a;专注于Java&#xff08;springboot ssm springcloud&#xff09; vue .net php phython node.js uniapp小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设&#xff0c;从业十五余年开发设计教学工作☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次…

【Windows】【DevOps】Windows Server 2022 在线/离线 安装openssh实现ssh远程登陆powershell、scp文件拷贝

服务器在线安装openssh 管理员权限启动powershell&#xff0c;输入指令 查看默认安装状态 Get-WindowsCapability -Online | Where-Object Name -like OpenSSH* 可以看到系统默认安装了客户端&#xff0c;未安装服务器端 安装服务器端 Add-WindowsCapability -Online -Nam…