QFile之文件操作

简述

1.本文讲述QFile的一些基本操作
2.用不同模式打开文件的影响:

  • ReadOnly (只读):如果该路径下文件不存在,则返回false,打开失败
  • WriteOnly (只写):如果该路径下文件不存在,自动创建文件,返回true,打开成功
  • ReadWrite(读写):如果该路径下文件不存在,自动创建文件,返回true,打开成功

QIODevice :: OpenMode

类型说明
QIODevice::NotOpen未打开。
QIODevice::ReadOnly只读模式打开。
QIODevice::WriteOnly只写模式打开。请注意,对于文件系统子类(例如QFile),此模式意味着Truncate,除非与ReadOnly,Append或NewOnly结合使用。
QIODevice::ReadWrite读写模式打开。
QIODevice::Append以追加模式打开,以便将所有数据写入文件末尾。
QIODevice::Truncate以重写的模式打开,之前的内容都将丢失。
QIODevice::Text读取时,行尾终止符被转换为'\ n'。写入时,行尾终止符将转换为本地编码,例如Win32的“\ r \ n”。
QIODevice::Unbuffered绕过缓冲区。
QIODevice::NewOnly如果要打开的文件已存在,则返回false。仅当文件不存在时才创建并打开该文件。操作系统保证您是唯一创建和打开文件的人。请注意,此模式表示WriteOnly,并允许将其与ReadWrite组合。此标志目前仅影响QFile。其他类可能在将来使用此标志,但在此之前将此标志与QFile以外的任何类一起使用可能会导致未定义的行为。(自Qt 5.11起)
QIODevice::ExistingOnly如果要打开的文件不存在则返回false。必须在ReadOnly,WriteOnly或ReadWrite旁边指定此标志。请注意,单独使用此标志与ReadOnly是多余的,因为当文件不存在时,ReadOnly已经失败。此标志目前仅影响QFile。其他类可能在将来使用此标志,但在此之前将此标志与QFile以外的任何类一起使用可能会导致未定义的行为。(自Qt 5.11起)

示例

QString str = qApp->applicationDirPath() + "/test.txt";
QFile fileName(str);

//判断文件是否存在
if (!fileName.exists())
{
    QMessageBox::warning(NULL, "warning", "文件不存在!");
}

//打开文件      只读ReadOnly  只写WriteOnly  读写ReadWrite
if (!fileName.open(QIODevice::ReadOnly | QIODevice::Text))
{
	QMessageBox::warning(NULL, "warning", QString("无法打开该文件:%1 (原因:%2)").arg(str).arg(fileName.errorString()));
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值