QT 文件操作 QFile

QT 文件操作 QFile输入/输出设备QIODevice类是Qt中所有I/O设备的基础接口类,为诸如QFile、QBuffer和QTcpSocket等支持读/写数据块的设备提供了一个抽象接口。QIODevice类是抽象的,无法被实例化,一般是使用它所定义的接口来提供设备无关的I/O功能。文件QFileQFile类提供一个用于读/写文件的接口,它是一个可以用来读写文本文件、二进制文件…

大家好,又见面了,我是你们的朋友全栈君。

目录

QFile类介绍

 写入数据到txt文件(实例代码)

从txt文件中读取所有数据(实例代码)

从txt文件中一行一行读取数据(实例代码)

部分函数参数及作用


 

QFile类介绍

QIODevice 类是 Qt 中所有 I/O 设备的基础接口类为诸如 QFile、QBuffer 和 QTcpSocket 等支持读/写数据块的设备提供了一个抽象接口。。

QFile类提供一个用于读/写文件的接口,它是一个可以用来读写文本文件、二进制文件和Qt资源的 I/O 设备。

QFile可以单独使用,也可以和QTextStream 或者QDataStream 一起使用。

一个文件使用open()打开,使用close()关闭,使用flush()刷新。

 

 

 写入数据到txt文件(实例代码)

QFile file("C:\\Users\\admin\\Desktop\\test.txt");
if(!file.open(QIODevice::WriteOnly))//以写的方式打开文件,如果文件不存在则创建,
    qDebug()<<file.errorString();

QByteArray buf = "bbbbbbbbbbb";
file.write(buf);//写入文件,支持QByteArray和 char * 类型数据写入

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

 

从txt文件中读取所有数据(实例代码)

QFile file("C:\\Users\\admin\\Desktop\\test.txt");
if(!file.open(QIODevice::ReadOnly))//以读的方式打开文件
    qDebug()<<file.errorString();

QByteArray buf = file.readAll();//读取文件所有数据
qDebug()<<"buf: "<<buf;

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

 

从txt文件中一行一行读取数据(实例代码)

QFile file("C:\\Users\\admin\\Desktop\\test.txt");
if(!file.open(QIODevice::ReadOnly))//以读的方式打开文件
    qDebug()<<file.errorString();

while(file.atEnd() == false)//文件没到末尾就执行循环体内容
{
    QByteArray buf = file.readLine();//读取一行的数据
    qDebug()<<buf;
}

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

 

 

 

部分函数参数及作用

文件的数据读/写一般使用QDataStream 或者 QTextStream 来完成,不过也可以使用继承自 QIODevice 类的一些函数,如:

QByteArray QIODevice::read(qint64 maxSize)

从设备读取最多最大大小的字节,并返回数据重组

qint64 QIODevice::read(char *data, qint64 maxSize)

从设备读取最多最大大小的字节的数据,并返回读取的字节数

qint64 QIODevice::readLine(char *data, qint64 maxSize)

此函数从设备读取一行 ASCII 字符, 最大最大最大大小为-1 字节, 将字符存储在数据中, 并返回读取的字节数。如果无法读取行, 但没有错误, 则此函数返回0。如果发生错误, 此函数返回可以读取的内容的长度, 如果未读取任何内容, 则返回-1。
readAll() 读取文件所有内容,读取之后将会处于文件的末尾

qint64 QIODevice::write(const char *data, qint64 maxSize)

将数据从数据到设备的最大最大最大大小字节写入设备。返回实际写入的字节数, 如果发生错误, 则返回-1。

qint64 QIODevice::write(const char *data)

将来自8位字符的零终止字符串的数据写入设备。返回实际写入的字节数, 如果发生错误, 则返回-1。

bool QIODevice::getChar(char *c)

从设备读取一个字符, 并将其存储在 c 中。如果 c 为 0, 则该字符将被丢弃。成功时返回 true;否则返回 false。(一次只操作一个字符)

bool QIODevice::putChar(char c)

将字符 c 写入设备。成功时返回 true;否则返回 false。(一次只操作一个字符)

void QIODevice::ungetChar(char c)

将字符 c 放回设备, 并减少当前位置, 除非位置为0。此函数通常被调用为 “撤消” getChar () 操作, 例如在编写回溯分析器时。
如果以前未从设备读取 c, 则该行为未定义。(一次只操作一个字符)

[virtual] qint64 QFile::size() const

获取文件的大小

[virtual] bool QFileDevice::seek(qint64 pos)

定位到文件的任意位置

[virtual] qint64 QFileDevice::pos() const

获取当前的位置

[virtual] bool QFileDevice::atEnd() const

判断是否到达了文件的末尾(如果已达到文件的末尾, 则返回 true。否则返回 false。)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/131148.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号