Qt QFile文件操作详解

本文详细介绍了Qt框架中QFile类的使用方法,包括文件的读取、写入、删除、重命名、拷贝等操作。并通过两个实例展示了如何读写文本文件和二进制文件。

很多应用程序都需要具备操作文件的能力,包括对文件内容进行读/写、创建和删除文件等,甚至某些应用程序的诞生纯粹是为了操作文件,比如 WPS Office、PDFedit 等。为此,Qt 框架提供了 QFile 类专门用来操作文件。

QFile文件操作

QFile 类支持对文件进行读取、写入、删除、重命名、拷贝等操作,它既可以操作文件文件,也可以操作二进制文件。

使用 QFile 类操作文件之前,程序中需引入<QFile>头文件。创建 QFile 类的对象,常用的构造函数有:

QFile::QFile()
QFile::QFile(const QString &name)

参数 name 用来指定要操作的目标文件,包含文件的存储路径和文件名,存储路径可以使用绝对路径(比如 "D:/Demo/test.txt")或者相对路径(比如"./Demo/test.txt"),路径中的分隔符要用 "/" 表示。

通常情况下,我们会调用第二个构造函数,直接指明要操作的文件。对于第一个构造函数创建的 QFile 对象,需要再调用 setFileName() 方法指明要操作的文件。

与 C++ 读写文件的规则一样,使用 QFile 读写文件之前必须先打开文件,调用 open() 成员方法即可,常用的语法格式为:

bool QFile::open(OpenMode mode)

mode 参数用来指定文件的打开方式,下表罗列了此参数的可选值以及各自的含义:
 

表 1 QFile文件打开方式
打开方式 含 义
QIODevice::ReadOnly 只能对文件进行读操作
QIODevice::WriteOnly 只能对文件进行写操作,如果目标文件不存在,会自行创建一个新文件。
QIODevice::ReadWrite 等价于 ReadOnly | WriteOnly,能对文件进行读和写操作。
QIODevice::Append 以追加模式打开文件,写入的数据会追加到文件的末尾(文件原有的内容保留)。
QIODevice::Truncate 以重写模式打开,写入的数据会将原有数据全部清除。注意,此打开方式不能单独使用,通常会和 ReadOnly 或 WriteOnly 搭配。
QIODevice::Text 读取文件时,会将行尾结束符(Unix 系统中是 "\n",Windows 系统中是 "\r\n")转换成‘\n’;将数据写入文件时,会将行尾结束符转换成本地格式,例如 Win32 平台上是‘\r\n’。


根据需要,可以为 mode 参数一次性指定多个值,值和值之间用|分割。比如:

  • QIODevice::ReadOnly | QIODevice::Text:表示只允许对文件进行读操作,读取文件时,会将行尾结束符转换为 '\n';
  • QIODevice::WriteOnly | QIODevice::Text:表示只允许对文件进行写操作,将数据写入文件时,会将行尾结束符转换为本地格式;
  • QIODevice::ReadWrite | QIODevice::Append | QIODevice::Text:表示对文件进行写操作,写入的数据会存放到文件的尾部,同时数据中的行尾结束符转换为本地格式。

注意,传递给 mode 参数的多个值之间不能相互冲突,比如 Append 和 Truncate 不能同时使用。

如果文件成功打开,open() 函数返回 true,否则返回 false。

QFile 类提供了很多功能实用的方法,可以快速完成对文件的操作,下表列举了常用的一些:
 

表 2 QFile常用方法
普通成员方法 功 能
qint64 QFile::size() const 获取当前文件的大小。对于打开的文件,该方法返回文件中可以读取的字节数。
bool QIODevice::getChar(char *c) 从文件中读取一个字符,并存储到 c 中。读取成功时,方法返回 true,否则返回 false。
bool QIODevice::putChar(char c) 向文件中写入字符 c,成功时返回 true,否则返回 false。
QByteArray QIODevice::read(qint64 maxSize) 从文件中一次性最多读取 maxSize 个字节,然后返回读取到的字节。
qint64 QIODevice::read(char *data, qint64 maxSize) 从文件中一次性对多读取 maxSi
QtQFile 类提供了一种方便的方式来访问和操作文。它支持文的读写、复制、移动、删除等操作。下面是 QFile 的一些常用方法和详细介绍。 1. 打开和关闭文 QFile 可以通过构造函数或 open() 方法打开一个文。例如: ```cpp QFile file("test.txt"); if (file.open(QIODevice::ReadOnly)) { // 文打开成功,进行读取操作 file.close(); } ``` 在上面的例子中,我们使用了 `QIODevice::ReadOnly` 标志来指示文只能读取,不能写入。其他可用的标志包括 `QIODevice::WriteOnly`、`QIODevice::ReadWrite`、`QIODevice::Append` 等。当文打开成功后,我们需要在操作完成后使用 `close()` 方法关闭文。 2. 读取文内容 QFile 可以使用 `readAll()` 方法一次性读取整个文的内容: ```cpp QFile file("test.txt"); if (file.open(QIODevice::ReadOnly)) { QByteArray data = file.readAll(); // 处理读取的数据 file.close(); } ``` 也可以使用 `read()` 方法读取部分文内容: ```cpp QFile file("test.txt"); if (file.open(QIODevice::ReadOnly)) { QByteArray data = file.read(1024); // 处理读取的数据 file.close(); } ``` 其中,`1024` 表示要读取的字节数。如果需要一行一行地读取文内容,可以使用 `readLine()` 方法: ```cpp QFile file("test.txt"); if (file.open(QIODevice::ReadOnly)) { while (!file.atEnd()) { QByteArray line = file.readLine(); // 处理读取的一行数据 } file.close(); } ``` 上面的代码片段将逐行读取文的内容,直到文末尾。 3. 写入文内容 QFile 可以使用 `write()` 方法写入数据到文中: ```cpp QFile file("test.txt"); if (file.open(QIODevice::WriteOnly)) { QByteArray data = "Hello, world!"; file.write(data); file.close(); } ``` 如果需要在文末尾追加数据,可以使用 `QIODevice::Append` 标志打开文,然后使用 `write()` 方法写入数据。 4. 复制、移动和删除文 QFile 可以使用 `copy()` 方法复制文: ```cpp QFile file("test.txt"); if (file.copy("copy.txt")) { // 文复制成功 } ``` 可以使用 `rename()` 方法移动或重命名文: ```cpp QFile file("test.txt"); if (file.rename("newname.txt")) { // 文移动或重命名成功 } ``` 可以使用 `remove()` 方法删除文: ```cpp QFile file("test.txt"); if (file.remove()) { // 文删除成功 } ``` 以上是 QFile 类的一些常用方法,可以根据需要进行调用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蝈蝈(GuoGuo)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值