庫的設置 hv庫
外部包含目錄:…\include\libhv_new\hv;
庫目錄:…\include\libhv_new\lib\x86\Release;
附加依賴項:hv.lib;
//Get請求 獲取json數據,然后提取符合 條件的,time值大于自定義變量的值,然后取出來,再抽取自定義個數,比如3個,把name拼接返回,再把數據放進動態數組也返回,兩種類型的返回!23-11-21#include "requests.h"
#include <unordered_set>
struct DataItem {int id;std::wstring name;bool isChange;
};
using Json = nlohmann::json;
std::vector<DataItem> dataItems;struct ServerDataResult {std::wstring concatenatedNames;std::vector<DataItem> dataItems;
};
//--------------str 轉 wstr 的三種方法 -----------------
std::wstring convertToWideString1(const std::string& str) {std::wstring wideStr(str.begin(), str.end());return wideStr;//構造函數 更簡潔
}
std::wstring convertToWideString2(const std::string& str) {std::wstring wideStr;wideStr.resize(str.size(), L' ');std::copy(str.begin(), str.end(), wideStr.begin());return wideStr;
}
//-----------------第三種通用,但需要頭文件--------------------------
#include <locale>
#include <codecvt>
/*
這種方法使用了 std::wstring_convert 類模板和 std::codecvt_utf8 類模板,它們提供了跨平臺的支持,能夠在不同的字符編碼環境中進行字符串轉換。
這里的示例使用了 UTF-8 編碼,你可以根據需要選擇其他字符編碼,如 UTF-16 或 UTF-32。
這種方法的優點是它是標準庫提供的通用解決方案,不依賴于特定的平臺或編譯器。它能夠在不同的機器和代碼之間保持一致,并且適用于大多數常見的字符編碼方案。
*/
std::wstring convertToWideString3(const std::string& str) {std::wstring_convert<std::codecvt_utf8<wchar_t>> converter;return converter.from_bytes(str);
}std::string convertToNarrowString(const std::wstring& wstr) {std::wstring_convert<std::codecvt_utf8<wchar_t>> converter;return converter.to_bytes(wstr);
}
//==========================================================================================std::pair<std::wstring, std::vector<DataItem>> GetServerData(int numNamesToExtract, int times) {std::wstring concatenatedNames{};std::vector<DataItem> dataItems;printf("等待網站返回數據中.....\n");// 發起 HTTP 請求獲取數據requests::Response resp = requests::get("http://124.222.37.232/api/list?ok=1");if (resp->status_code != 200) {printf("Request failed!\n");return std::make_pair(L"", dataItems);}// 解析返回的JSONJson json;try {json = Json::parse(resp->body); // 使用 parse() 方法解析 JSON 字符串}catch (const nlohmann::json::parse_error& e) {printf("Failed to parse JSON: %s\n", e.what());return std::make_pair(L"", dataItems);}//===========打印所有數據======printf("Complete data:\n");printf("%s\n", json.dump().c_str()); // 打印全部網站獲取的數據// 檢查 JSON 數據中的字段if (json.is_object() && json.contains("total") && json["total"].is_number()) {int total = json["total"];printf("Total count: %d\n", total);if (json.contains("data") && json["data"].is_array()) {const nlohmann::json& dataArray = json["data"];srand(static_cast<unsigned int>(time(nullptr)));std::vector<const nlohmann::json*> filteredData;// 過濾符合條件的數據for (const nlohmann::json& item : dataArray) {if (item.is_object() && item.contains("name") && item["name"].is_string()&& item.contains("time") && item["time"].is_string()) {std::string time = item["time"].get<std::string>();int timeValue = std::stoi(time);if (timeValue < times) {filteredData.push_back(&item);}}}// 隨機選擇 numNamesToExtract 個名稱std::vector<size_t> randomIndices;if (filteredData.size() <= static_cast<size_t>(numNamesToExtract)) {// 數據量不足 numNamesToExtract 個時,選擇全部數據for (size_t i = 0; i < filteredData.size(); ++i) {randomIndices.push_back(i);}}else {// 數據量足夠時,隨機選擇 numNamesToExtract 個索引std::unordered_set<size_t> selectedIndices;while (selectedIndices.size() < static_cast<size_t>(numNamesToExtract)) {size_t randomIndex = rand() % filteredData.size();selectedIndices.insert(randomIndex);}randomIndices.assign(selectedIndices.begin(), selectedIndices.end());}// 提取名稱數據for (size_t index : randomIndices) {const nlohmann::json& item = *filteredData[index];std::string name = item["name"].get<std::string>();std::string time = item["time"].get<std::string>();std::wstring wideName = convertToWideString3(name);DataItem dataItem;dataItem.id = static_cast<int>(dataItems.size()) + 1;dataItem.name = wideName;dataItem.isChange = false; // 默認設置為 false,因為無法比較之前的數據dataItems.push_back(dataItem);if (!concatenatedNames.empty()) {concatenatedNames += L",";}concatenatedNames += wideName;// 輸出 "time" 字段的值進行調試printf("Time value: %s\n", time.c_str());}const wchar_t* tCharStr = concatenatedNames.c_str();printf("Concatenated names: %ls\n", tCharStr);}}else {printf("Failed to parse 'total' field!\n");}// 打印 dataItems 中的數據printf("DataItems:\n");for (const DataItem& item : dataItems) {printf("ID: %d, Name: %ls \n", item.id, item.name.c_str());// 打印其他字段的值}return std::make_pair(concatenatedNames, dataItems);
}int main() {int numNamesToExtract = 3;int times = 50;std::pair<std::wstring, std::vector<DataItem>> result = GetServerData(numNamesToExtract, times);std::wstring concatenatedNames = result.first;std::vector<DataItem> dataItems = result.second;std::wcout << "Concatenated Names: " << concatenatedNames << std::endl;for (const auto& item : dataItems) {std::wcout << "ID: " << item.id << std::endl;std::wcout << "Name: " << item.name << std::endl;// 打印其他字段的值std::wcout << std::endl;}return 0;
}
運行結果: