库的设置 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;
}
运行结果: