版权声明:版权声明:本文章刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等均归"江南、董少"所有! 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模块