【QT系统相关】QT文件

发布于:2025-06-15 ⋅ 阅读:(16) ⋅ 点赞:(0)

目录

1. Qt 文件概述

2. 输入输出设备类

3 文件读写类

读取文件内容

写文件

实现一个简单的记事本

4. 文件和目录信息类


QT专栏:QT_uyeonashi的博客-CSDN博客

1. Qt 文件概述

文件操作是应用程序必不可少的部分。Qt 作为一个通用开发库,提供了跨平台的文件操作能力。 Qt提供了很多关于文件的类,通过这些类能够对文件系统进行操作,如文件读写、文件信息获取、文件复制或重命名等。

2. 输入输出设备类

在 Qt 中,文件读写的类为 QFile 。QFile 的父类为 QFileDevice ,QFileDevice 提供了文件交互操作的底层功能。 QFileDevice 的父类是 QIODevice,QIODevice 的父类为 QObject 。
QIODevice 是 Qt 中所有输入输出设备(input/output device,简称 I/O 设备)的基础类,I/O 设备就是能进行数据输入和输出的设备,例如文件是一种 I/O 设备,网络通信中的 socket 是 I/O 设备, 串口、蓝牙等通信接口也是 I/O 设备,所以它们也是从 QIODevice 继承来的。Qt 中主要的一些 I/O 设备类的继承关系如下图所示:

上图中各类的说明如下:
• QFile 是用于文件操作和文件数据读写的类,使用 QFile 可以读写任意格式的文件。
• QSaveFile 是用于安全保存文件的类。使用 QSaveFile 保存文件时,它会先把数据写入一个临时文件,成功提交后才将数据写入最终的文件。如果保存过程中出现错误,临时文件里的数据不会被写入最终文件,这样就能确保最终文件中不会丢失数据或被写入部分数据。 在保存比较大的文件或复杂格式的文件时可以使用这个类,例如从网络上下载文件等。
• QTemporaryFile 是用于创建临时文件的类。使用函数 QTemporaryFile::open() 就能创建一个文件名唯一的临时文件,在 QTemporaryFile 对象被删除时,临时文件被自动删除。
• QTcpSocket 和 QUdpSocket 是分别实现了 TCP 和 UDP 的类。
• QSerialPort 是实现了串口通信的类,通过这个类可以实现计算机与串口设备的通信。
• QBluetoothSocket 是用于蓝牙通信的类。手机和平板计算机等移动设备有蓝牙通信模块,笔记本电脑一般也有蓝牙通信模块。通过QBluetoothSocket类,就可以编写蓝牙通信程。如编程实现笔记本电脑与手机的蓝牙通信。
• QProcess 类用于启动外部程序,并且可以给程序传递参数。
• QBuffer 以一个 QByteArray 对象作为数据缓冲区,将 QByteArray 对象当作一个 I/O 设备来写。

3 文件读写类

在 Qt 中,文件的读写主要是通过 QFile 类来实现。在 QFile 类中提供了一些用来读写文件的方法。对于文件的操作主要有:
• 读数据:QFile 类中提供了多个方法用于读取文件内容;如 read()、readAll()、readLine()等。
• 写数据:QFile 类中提供了多个方法用于往文件中写内容;如 write()、writeData()等。
• 关闭文件:文件使用结束后必须用函数 close() 关闭文件。
访问一个设备之前,需要使用 open()函数 打开该设备,而且必须指定正确的打开模式,QIODevice 中所有的打开模式由 QIODevice::OpenMode 枚举变量定义,其取值如下:

读取文件内容

1. 新建 Qt 项目,在 UI 文件中拖入一个 LineEdit,一个pushButton,一个 TextEdit。当点击按钮时,弹出窗口选择要读取的文件,并将读取到的内容在 TextEdit 中显示;

2. 在 "widget.cpp" 文件中实现对应功能;

#include "widget.h"
#include "ui_widget.h"
#include <QFileDialog>
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    connect(ui->btn,&QPushButton::clicked,[=](){
    QString path = QFileDialog::getOpenFileName(this,"打开文件","C:\\Users\\Lenovo\\Desktop");
    ui->lineEdit->setText(path);

    QFile file(path); //path:代表文件路径this

    //打开文件
    file.open(QIODevice::ReadOnly); //以只读的方式打开文件
    QString str = file.readAll();
    ui->textEdit->setText(str);

    //关闭文件
    file.close();
    });
}

写文件

在上述示例的基础上修改 "widget.cpp" 文件;

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

    connect(ui->btn,&QPushButton::clicked,[=](){
    QString path = QFileDialog::getOpenFileName(this,"打开文件","C:\\Users\\Lenovo\\Desktop");
    ui->lineEdit->setText(path);
    QFile file(path); //path:代表文件路径

    //打开文件 进行写操作
    file.open(QIODevice::Append); //以追加的方式进行写
    file.write("【这是示例!!!】");

    //关闭文件
    file.close();
    });
}

 

实现一个简单的记事本

//  mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QPlainTextEdit>
#include <QFileDialog>

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

    this->setWindowTitle("简单的记事本");

     QMenuBar* menuBar = this->menuBar();

     QMenu* menu = new QMenu("文件");
     menuBar->addMenu(menu);

     QAction* action1 = new QAction("打开");
     QAction* action2 = new QAction("保存");
     menu->addAction(action1);
     menu->addAction(action2);

     edit = new QPlainTextEdit();
     QFont font;
     font.setPixelSize(20);
     edit->setFont(font);
     this->setCentralWidget(edit);

     connect(action1,&QAction::triggered,this,&MainWindow::handleAction1);
     connect(action2,&QAction::triggered,this,&MainWindow::handleAction2);

}

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

void MainWindow::handleAction1()
{   //打开文件,选择打开哪个文件
    QString path = QFileDialog::getOpenFileName(this);

    //把文件名显示到状态栏
    QStatusBar* statusBar = this->statusBar();
    statusBar->showMessage(path);

    //根据选择的路径构建QFIle对象,并打开文件
    QFile file(path);
    bool ret = file.open(QFile::ReadOnly);
    if(!ret)
    {
        statusBar->showMessage(path + "打开失败");
        return;
    }
    //读取文件
    QString text = file.readAll();
    file.close();

    //对到的内容设置到输入框中
    edit->setPlainText(text);
}

void MainWindow::handleAction2()
{   //保存文件
     QString path = QFileDialog::getSaveFileName(this);

     //在状态栏中显示这个文件名
     QStatusBar* statusBar = this->statusBar();
     statusBar->showMessage(path);

     //根据选择路径,构建QFile对象,并打开文件
     QFile file(path);
     bool ret = file.open(QFile::WriteOnly);
     if(!ret)
     {
         statusBar->showMessage(path + "打开失败");
         return;
     }
     //写文件
     const QString& text = edit->toPlainText();
     file.write(text.toUtf8());

     file.close();
}

 

4. 文件和目录信息类

 QFileInfo 是 Qt 提供的一个用于获取文件和目录信息的类,如获取文件名、文件大小、文件修改日期等。QFileInfo类中提供了很多的方法,常用的有:
• isDir() 检查该文件是否是目录;
• isExecutable() 检查该文件是否是可执行文件;
• fileName() 获得文件名;
• completeBaseName() 获取完整的文件名;
• suffix() 获取文件后缀名;
• completeSuffix() 获取完整的文件后缀;
• size() 获取文件大小;
• isFile() 判断是否为文件;
• fileTime() 获取文件创建时间、修改时间、最近访问时间等;

示例:
在 "widget.cpp" 文件中添加如下代码:

#include <QFileInfo>
#include <QFileDialog>
#include <QDebug>
#include <QDateTime>

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

    connect(ui->btn,&QPushButton::clicked,[=](){
    QString path = QFileDialog::getOpenFileName(this,"打开文件","C:\\Users\\Lenovo\\Desktop");

    //QFileInfo 文件信息类
    QFileInfo fileinfo(path);

    //文件名
    qDebug() << "文件名为:" << fileinfo.fileName().toUtf8().data();

    //文件后缀名
    qDebug() << "后缀名为:" << fileinfo.suffix().toUtf8().data();

    //文件大小
    qDebug() << "文件大小为:" << fileinfo.size();

    //文件路径
    qDebug() << "文件路径为:" << fileinfo.path().toUtf8().data();

    //判断是否为文件
    qDebug() << "是否为文件:"<< fileinfo.isFile();

    //文件创建时间
    QDateTime time1 = fileinfo.fileTime(QFileDevice::FileBirthTime);
    qDebug() << "创建时间为:" << time1.toString("yyyy-MM-dd
    hh:mm:ss").toUtf8().data();

    //文件的最后修改日期
    QDateTime time2 = fileinfo.lastModified();
    qDebug() << "最后修改时间为:"<< time2.toString("yyyy-MM-dd
    hh:mm:ss").toUtf8().data();

    //判断是否为文件夹
    qDebug() << "是否为目录:" << fileinfo.isDir();
    });
}


本篇完!