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