本文目錄一覽:
qt 怎樣將conf配置文件 轉json配置文件
在Windows操作系統中,大多把配置文件信息寫在註冊表當中,或寫在*.ini文件中,對於這兩種操作都有相應的Windows API函數,在以前的文章中都提及過,這裡就不多說了~
在Qt中,提供了一個相應的配置文件的類QSetting,使用QSetting類,可以將用戶設置以及應用程序的設置輕鬆存儲在磁碟中。
QSettings::Format(配置存儲格式)分為NativeFormat、IniFormat、InvalidFormat。這裡主要講的是NativeFormat和IniFormat。
QSettings::NativeFormat:在Windows中,利用系統註冊表來存儲;在 Mac OS X中,使用系統的CFPreferences機制來存儲(使用Core Foundation Preference API);在其他平台中,設置則存儲在文本文件中。
QSettings::IniFormat:讀寫*.ini格式的配置文件,NativeFormat在某些操作系統中的擴展名是*.conf。
QSettings::Scope(配置存儲範圍)分為UserScope、SystemScope。
QSettings::UserScope:用戶環境,設置在當前用戶的特定位置中。
QSettings::SystemScope:系統環境,設置在全局型,所有用戶均可獲得。
請教Qt如何解析出Json的數據
JSON(JavaScript Object Notation)是一種輕量級的數據交換格式。它基於JavaScript(Standard ECMA-262 3rd Edition – December 1999)的一個子集。 JSON採用完全獨立於語言的文本格式,但是也使用了類似於C語言家族的習慣(包括C、C++、C#、Java、JavaScript、Perl、Python等)。這些特性使JSON成為理想的數據交換語言。易於人閱讀和編寫,同時也易於機器解析和生成。
常用的Json庫
JsonCpp
JsonCpp是一個C++用來處理JSON數據的開發包。
網址:.
cJSON
cJSON是一個超輕巧,攜帶方便,單文件,簡單的可以作為ANSI-C標準的JSON解析器。
網址:.
QJson
QJson是一個基於Qt的開發包用來將JSON數據解析成QVariant對象,JSON的數組將被映射為QVariantList實例,而其他對象映射為QVariantMap實例。
網址:.
關於Qt中對JSON的生成與解析,Qt5以前的版本,需要去進行單獨下載、編譯,才能使用。到了Qt5,提供了專門的QJsonDocument類來讀取和寫入JSON文檔。
Qt5中JSON的生成與解析
QJsonDocument
QJsonDocument既可以從一個基於文本表示的UTF-8編碼,又可以從Qt自己的二進位格式讀取和寫入這個文件。
JSON文檔可以從它的基於文本的表示使用QJsonDocument::fromJson()轉換為QJsonDocument,用.toJSON()將其轉換迴文字。解析器非常快速和高效,將JSON轉換為二進位表示。
QJsonObject
QJsonObject類用於封裝JSON對象。
JSON對象是鍵值對,其中鍵是唯一的字元串,其值由QJsonValue代表。一個QJsonObject可以從QVariantMap轉換/被轉換。
QJsonArray
QJsonArray類用於封裝JSON數組。
一個JSON數組列表值。該列表可以通過從陣列插入和移除QJsonValue的操縱。一個QJsonArray可以從QVariantList轉換為/被轉換。
QJsonDocument有效解析後的文檔可以使用!iSNull()判斷。使用isArray()和isObject()來判斷是否包含一個數組或對象。文檔中包含的數組或對象可以使用array()或object()進行檢索,然後讀取或操縱。
示例
QJsonObject
(1)生成Json
QJsonObject json;
json.insert(“name”, QString(“Qt”));
json.insert(“version”, 5);
json.insert(“windows”, true);
QJsonDocument document;
document.setObject(json);
QByteArray byte_array = document.toJson(QJsonDocument::Compact);
QString json_str(byte_array);
結果:
json_str:{“name”: “Qt”,”version”: 5,”windows”: true}
(2)解析Json
QJsonParseError json_error;
QJsonDocument parse_doucment = QJsonDocument::fromJson(byte_array, json_error);
if(json_error.error == QJsonParseError::NoError)
{
if(parse_doucment.isObject())
{
QJsonObject obj = parse_doucment.object();
if(obj.contains(“name”))
{
QJsonValue name_value = obj.take(“name”);
if(name_value.isString())
{
QString name = name_value.toString();
}
}
if(obj.contains(“version”))
{
QJsonValue version_value = obj.take(“version”);
if(version_value.isDouble())
{
int version = version_value.toVariant().toInt();
}
}
if(obj.contains(“windows”))
{
QJsonValue version_value = obj.take(“windows”);
if(version_value.isBool())
{
bool flag = version_value.toBool();
}
}
}
}
結果:
name:Qt
version:5
windows:true
QJsonArray
(1)生成Json
QJsonArray json;
json.insert(0, QString(“Qt”));
json.insert(1, QString(“version”));
json.insert(2, true);
QJsonDocument document;
document.setArray(json);
QByteArray byte_array = document.toJson(QJsonDocument::Compact);
QString json_str(byte_array);
結果:
json_str:[“Qt”,”version”,true]
(2)解析Json
QJsonParseError json_error;
QJsonDocument parse_doucment = QJsonDocument::fromJson(byte_array, json_error);
if(json_error.error == QJsonParseError::NoError)
{
if(parse_doucment.isArray())
{
QJsonArray array = parse_doucment.array();
int size = array.size();
for(int i=0; i
{
QJsonValue value = array.at(i);
if(value.isString())
{
QString name = value.toString();
}
else if(value.isBool())
{
bool flag = value.toBool();
}
}
}
}
結果:
數組不同下標對應的值
0:Qt
1:version
2:true
如上,簡單介紹一下常用的JSON庫以及Qt中對JSON的生成與解析,如需更多資料請參考官方文檔,還是那句話,沒有比助手更好、更專業的資料了!
Qt如何將對象轉換為JSON格式的
自動轉肯定是不可能了,要自己寫代碼。
qt5的話可以直接用QJsonDocument、QJsonObject、QJsonValue、QJsonArray,
qt4.8的話建議去網上找一個開源的json類來用
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/251003.html