我正在寻找覆盖文本文件中的数据,但我似乎所能做的就是附加到它
mFile.open(QFile::ReadWrite)
QTextStream in(&mFile);
QString first = in.readLine(); //discard the headers
QString dataLine = in.readLine(); //headers
QStringList sql_row = dataLine.split("\t"); //first row (sake of proj only 1 row)
if(sql_row[1].isEmpty()) //no user name registered
{
QByteArray user= getenv("USERNAME"); //for windows
if(user.isEmpty())
{
user = getenv("USER"); ///for MAc or Linux
}
dataLine = dataLine.insert(dataLine.indexOf("\t")+ 1,user);
in << first << endl << dataLine << endl;
mFile.flush();
mFile.close();
最佳答案
改变
mFile.open(QFile::ReadWrite);
到mFile.open(QIODevice::ReadWrite | QIODevice::Truncate | QIODevice::Text);
QIODevice 与 QFile 的区别不是必需的,但我个人更喜欢使用基类。 Truncate
flag 将覆盖(即删除)现有文件。或者,您可以关注 other suggestion并使用 QTextStream 的构造函数之一直接打开您的文本文件。一样的
QIODevice::OpenMode
公约适用。这仅适用于 mFile
是 FILE
对象而不是 QFile
,在您的示例中并非如此。给初学者的一些附加说明。
相关注释1
你没有问这个,但我也添加了
QIODevice::Text
标志以确保在使用 \n
时将换行符转换为本地编码(纯 \r\n
与 endl
相比) .一个非常常见的错误是使用
\r\n
和 QIODevice::Text
,这导致文本文件具有双返回 \r\r\n
在 Windows 上。只需使用 QIODevice::Text
打开时只需\n
或 endl
你永远不会有这个问题。相关说明2
使用 QTextStream::endl会自动调用
flush()
每一次。如果您的循环很大,请使用 "\n"
相反,以防止减速,除非您确实需要刷新每一行。当缓冲区已满或关闭时,流将自动写入磁盘。QFile::close()也调用
flush()
,这使您的 mFile.flush()
最后是多余的。
关于qt - 覆盖文本文件与追加,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13314289/