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()));
}

你可能感兴趣的:(QT)