QT 文件操作 QFile

输入/输出设备

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

 

文件QFile

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

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

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

 

文件的数据读/写一般使用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。)

例子(创建文件并写入数据):

//以只写的方式打开,如果文件不存在,那么会创建该文件
    QFile file("myfile.txt");
    if(!file.open(QIODevice::WriteOnly | QIODevice::Text))
        qDebug()<

 

你可能感兴趣的:(QT)