C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))
文件的讀寫是很多應(yīng)用程序具有的功能,甚至某些應(yīng)用程序就是圍繞著某一種格式文件的處 理而開發(fā)的,所以文件讀寫是應(yīng)用程序開發(fā)的一個(gè)基本功能。
Qt文件操作有兩種方式,第一種使用QFile類的IODevice讀寫功能直接讀寫,第二種是利用 QFile和QTextStream結(jié)合起來,用流的方式進(jìn)行文件讀寫。
第一種,利用QFile中的相關(guān)函數(shù),實(shí)現(xiàn)對(duì)文件的讀寫操作,QFile會(huì)調(diào)用IODevice設(shè)備,從而實(shí)現(xiàn)文件讀寫。
QT基本文件讀寫
通過QFile實(shí)現(xiàn)文本文件讀寫操作.
#include <QCoreApplication>
#include <iostream>
#include <QFile>
#include <QString>
#include <QTextStream>
// 一次讀入所有文本
bool ReadFileOnly(const QString &file_path)
{
QFile ptr(file_path);
// 文件是否存在
if(!ptr.exists())
{
return false;
}
// 文件是否打開
/*
ReadOnly 以只讀方式打開
WriteOnly 以只寫方式打開
ReadWrite 讀寫方式打開
Append 以追加方式打開
Truncate 以截取方式打開(原有內(nèi)容被清空)
Text 以文件方式打開
*/
if(!ptr.open(QIODevice::ReadWrite | QIODevice::Text))
{
return false;
}
QString text = ptr.readAll();
std::cout << text.toStdString() << std::endl;
ptr.close();
}
// 追加寫入文本
bool WriteFileOnly(const QString &file_path, QString save)
{
// 如果參數(shù)為空則返回假
if(file_path.isEmpty() && save.isEmpty())
{
return false;
}
QFile ptr(file_path);
if(!ptr.open(QIODevice::Append | QIODevice::Text))
{
return false;
}
QByteArray str_bytes = save.toUtf8();
ptr.write(str_bytes,str_bytes.length());
ptr.close();
return true;
}
QFile::open() 函數(shù)打開文件時(shí)需要傳遞 QIODevice::OpenModeFlag 枚舉類型的參數(shù),決定文件以什么方式打開,QIODevice::OpenModeFlag 類型的主要取值如下:
QIODevice::ReadOnly:以只讀方式打開文件,用于載入文件。
QIODevice::WriteOnly:以只寫方式打開文件,用于保存文件。
QIODevice::ReadWrite:以讀寫方式打開。
QIODevice::Append:以添加模式打開,新寫入文件的數(shù)據(jù)添加到文件尾部。
QIODevice::Truncate:以截取方式打開文件,文件原有的內(nèi)容全部被刪除。
QIODevice::Text:以文本方式打開文件,讀取時(shí)“\n”被自動(dòng)翻譯為換行符,寫入時(shí)字符串結(jié)束符會(huì)自動(dòng)翻譯為系統(tǒng)平臺(tái)的編碼,如 Windows 平臺(tái)下是“\r\n”。
這些取值可以組合,例如 QIODevice::ReadOnly | QIODevice::Text 表示以只讀和文本方式打開文件。
QTextStream 實(shí)現(xiàn)流讀寫
直接使用流寫入,可以使用<< 運(yùn)算符,方便的寫入文本。
#include <QCoreApplication>
#include <iostream>
#include <QFile>
#include <QString>
#include <QTextStream>
#include <QTextCodec>
// 計(jì)算文件行數(shù)
qint32 get_file_count(const QString &file_path)
{
QFile ptr(file_path);
qint32 count = 0;
if(ptr.open(QIODevice::ReadOnly | QIODevice::Text))
{
QTextStream in(&ptr);
// 自動(dòng)檢測(cè)unicode編碼,顯示中文
in.setAutoDetectUnicode(true);
while(!in.atEnd())
{
QString line = in.readLine();
std::cout << line.toStdString() << std::endl;
count = count +1;
}
return count;
}
return 0;
}
// 追加寫入數(shù)據(jù)
bool write_file_stream(const QString &file_path, QString save)
{
QFile ptr(file_path);
if(ptr.open(QIODevice::Append | QIODevice::Text))
{
QTextStream in(&ptr);
in << save;
}
ptr.close();
return true;
}
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
// 設(shè)置編碼
QTextCodec *codec = QTextCodec::codecForName("utf-8");
QTextCodec::setCodecForLocale(codec);
// 流寫入
write_file_stream("d://test.txt","hello lyshark");
write_file_stream("d://test.txt","你好,世界");
// 取文本長度
qint32 count = get_file_count("d://test.txt");
std::cout << "line = > " << count << std::endl;
return a.exec();
}
到此這篇關(guān)于C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))的文章就介紹到這了,更多相關(guān)Qt 文件讀寫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從c++標(biāo)準(zhǔn)庫指針萃取器談一下traits技法(推薦)
本篇文章基于gcc中標(biāo)準(zhǔn)庫源碼剖析一下標(biāo)準(zhǔn)庫中的模板類pointer_traits,并且以此為例理解一下traits技法,對(duì)c++ traits技法源碼分析感興趣的朋友跟隨小編一起看看吧2021-07-07
C++實(shí)現(xiàn)班級(jí)成績管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)班級(jí)成績管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
C++11 模板參數(shù)的“右值引用”是轉(zhuǎn)發(fā)引用嗎
這篇文章主要介紹了C++11 模板參數(shù)的“右值引用”是轉(zhuǎn)發(fā)引用嗎,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05

