QT学习day10---ini文件、XML、MySQL数据库连接

版权声明:版权声明:本文章刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等均归"江南、董少"所有! https://blog.csdn.net/qq_41453285/article/details/84073887

 

一、ini文件

①语法:节、键、值组成

  • 节:section
  • 参数:(键=值)
  • ini文件注释一分号(;)开头

②QSettings

QT中对ini文件的操作使用到QSettings类

//函数
QSettings(ini路径文件名, QSettings::IniFormat); //构造函数
setIniCodec(QTextCodec::codecForName("utf-8"));//设置编码,utf-8格式
value(); //得到参数对应的文本
setValue(); //设置文本

beginGroup(section值); //开始一组section
endGroup(); //结束一组section

下面演示一个Tab Widget控件对ini文件的读取与写入

//ini文件数据读取到Tab Widget控件中

QFileInfo iniFileInfo = QFileInfo(iniPathString); //iniPathString为ini文件的路径
if(iniFileInfo.exists()) //如果ini文件存在
{
    QSettings *config = new QSettings(iniPathString, QSettings::IniFormat);
    config->setIniCodec(QTextCodec::codecForName("utf-8"));//设置ini文件为utf-8格式
    
    for(int i = 0; i < 10; i++)//假设最大十个section
    {
        QString section = QString("teacher%1/").arg(i);//格式化
        if(config->value(section + "name").toString().isEmpty())
        {
            continue;//空数据不做处理
        }
        currentRow = i; //当前行数
         ui->tableWidget->insertRow(i);//插入新行
        
        itemName = config->value(section + "name").toString();
        currentColumn = 0;
        ui->tableWidget->setItem(currentRow, currentColumn, new QTableWidgetItem(itemName));//插入第0行第0列
        
        itemName = config->value(section + "course").toString();
        currentColumn = 1;
        ui->tableWidget->setItem(currentRow, currentColumn, new         QTableWidgetItem(itemName));//插入0行第1列
        
        itemName = config->value(section + "time").toString();
        currentColumn = 2;
        ui->tableWidget->setItem(currentRow, currentColumn, new QTableWidgetItem(itemName));//插入第0行第2列
        
        itemName = config->value(section + "read").toString();
        currentColumn = 3;
        ui->tableWidget->setItem(currentRow, currentColumn, new QTableWidgetItem(itemName));//插入第0行第3列
    }
    delete config;
}
//将Tab Widget控件中的数据写入ini文件中

if(iniFileInfo.exists())//如果ini文件存在
{
    QSettings *config = new QSettings(iniPathString, QSettings::IniFormat);
    config->setIniCodec(QTextCodec::codecForName("utf-8"));//告诉Qt ini文件为utf-8格式
    
    for(int i = 0; i < ui->tableWidget->rowCount(); i++)
    {
        QString section = QString("teacher%1/").arg(i);
        config->beginGroup(section); //开始一组section
        config->setValue("name", ui->tableWidget->item(i, 0)->text());
        config->setValue("course", ui->tableWidget->item(i, 1)->text());
        config->setValue("time", ui->tableWidget->item(i, 2)->text());
        config->setValue("read", ui->tableWidget->item(i, 3)->text());
        config->endGroup();
    }
    delete config;
}

二、XML 

①概念:可扩展标记语言,是一种标记语言。一般用于数据存储、配置文件存储,(Qt的ui文件就是xml)也可以跨平台跨语言进行数据传输。

②语法:

  • 文档声明:<?xml version="1.0" encoding="utf‐8"?>
  • 标签成对存在,用<>包含,可以嵌套

③QT中操作XML语言

函数:QXmlStreamReader(读流)、QXmlStreamWriter(写流)

下面演示XML文件的读取与写入

QFile file("./testRead.xml");

if (!file.open(QFile::ReadOnly | QFile::Text))
{
    qDebug()<<"Error: cannot open file";
}

QXmlStreamReader reader; //读流
reader.setDevice(&file);//把文件塞进流

while (!reader.atEnd())//如果没有读到文档结尾,而且没有出现错误
{
    //读取下一个记号,它返回记号的类型
    QXmlStreamReader::TokenType type = reader.readNext();
    //下面便根据记号的类型来进行不同的输出
    if (type == QXmlStreamReader::StartDocument)
        qDebug() << reader.documentEncoding() << reader.documentVersion();//打印编码方式
    if (type == QXmlStreamReader::StartElement)//如果是开始标记
    {
        qDebug() << "<" << reader.name() << ">";
        if((reader.attributes().hasAttribute("id"))&&(reader.attributes().hasAttribute("time")))
        qDebug() << reader.attributes().value("id")<<" " <<reader.attributes().value("time");
    }
    if(type == QXmlStreamReader::EndElement)//如果是结尾标记
        qDebug() << "</" << reader.name() << ">";
    if (type == QXmlStreamReader::Characters && !reader.isWhitespace())
        qDebug() << reader.text();
        //listwidget->additem;
}

if (reader.hasError())//如果读取过程中出现错误,那么输出错误信息
{
    qDebug() << "error: " << reader.errorString();
}
file.close();
QFile file("./testWrite.xml");
if (!file.open(QFile::WriteOnly | QFile::Text))  //创建方式写
{
    qDebug() << "Error: cannot open file";
}

QXmlStreamWriter stream(&file);//准备好流

stream.setCodec(QTextCodec::codecForName("utf-8"));//设置为utf-8编码
stream.setAutoFormatting(true);

stream.writeStartDocument();//文档开始
stream.writeStartElement("teachers");//teachers

/*老王*/
stream.writeStartElement("teacher");
stream.writeAttribute("id", "01");//工号
stream.writeAttribute("time", "12:00");
stream.writeTextElement("name", QString::fromLocal8Bit("老王"));
stream.writeTextElement("book", QString::fromLocal8Bit("金瓶梅"));
stream.writeEndElement();

/* robort */
stream.writeStartElement("teacher");
stream.writeAttribute("id", "02");
stream.writeAttribute("time", "04:00");
stream.writeTextElement("name", "robort");
stream.writeTextElement("book", QString::fromLocal8Bit("葵花宝典"));
stream.writeEndElement();

/* 夏七 */
stream.writeStartElement("teacher");
stream.writeAttribute("id", "03");
stream.writeAttribute("time", "19:00");
stream.writeTextElement("name", QString::fromLocal8Bit("夏七"));
stream.writeTextElement("book", QString::fromLocal8Bit("红楼梦"));
stream.writeEndElement();

stream.writeEndElement();//teachers
stream.writeEndDocument();//文档结束
file.close();

三、MySQL数据库操作

Qt关联,MySQL数据库

  • 拷贝dll到相关目录
  • pro文件中添加sql模块

猜你喜欢

转载自blog.csdn.net/qq_41453285/article/details/84073887