170 похожих чатов

Привет. Есть вопрос: есть std::vector<std::unordered_map<std::string, std::string>> в этом векторе мап

в каждой мапе есть поле AttributeID и мне надо проверить значение, я могу конечно пройти по каждому элементу вектора и потом обратиться через .at("AttributeID") но чет мне кажется что в стл есть какой - то алгоритм. Попробовал std::find() и std::for_each и компилятор ругается. Неужели нет способа через библиотечные методы поиска найти интересующее меня значение? Так работает
for(auto &element : vect)
{
if(element.at("AttributeID") == "0")
std::cout << "\nresult = " << element.at("AttributeID");
}
Так нет
std::find(vect.begin(), vect.end(),[](auto & element)
{});

8 ответов

8 просмотров

Ну потому что во втором случае ты ищешь не в мапе, а мапы

замени find на find_if

Что значит "ПРОВЕРИТЬ ЗНАЧЕНИЕ" ? На что проверять?

Dmitriy-Kushnaryuk Автор вопроса
Ilya Zviagin
Что значит "ПРОВЕРИТЬ ЗНАЧЕНИЕ" ? На что проверять...

В мапе ключ значение. Надо проверить, что это значение есть например "0" по ключу AttributeID

У тебя второй пример просто не до конца дописан, он должен BOOL возвращать. А он ничего не возвращает (VOID)

Dmitriy-Kushnaryuk Автор вопроса
Ilya Zviagin
У тебя второй пример просто не до конца дописан, о...

Да, это косяк. Сделал в таком виде: std::find_if(std::begin(vect), std::end(vect), [](auto & element){ if(element.at("TBDAttributeID") == "0") { std::cout << "result = " << element.at("TBDAttributeID") << std::endl; return true; } else return false; });

Dmitriy Kushnaryuk
Да, это косяк. Сделал в таком виде: std::find_if(...

Тебе бы также следовало бы добавить тут везде модификаторы CONST

Похожие вопросы

Обсуждают сегодня

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Привет, не могли бы подсказать почему "A tree falls in a forest" не отображается в journalctl? openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1); syslog (LO...
•_• Asmanov 🎓
3
Карта сайта