Итак, у меня есть следующая строка данных, получаемых через TCP-соединение winsock, и я хотел бы выполнить расширенную токенизацию в вектор структур, где каждая структура представляет одну запись.
std::string buf = "44:william:adama:commander:stuff\n33:luara:roslin:president:data\n"
struct table_t
{
std::string key;
std::string first;
std::string last;
std::string rank;
std::additional;
};
Каждая запись в строке отделяется переводом каретки.Моя попытка разделить записи, но еще не разделить поля:
void tokenize(std::string& str, std::vector< string >records)
{
// Skip delimiters at beginning.
std::string::size_type lastPos = str.find_first_not_of("\n", 0);
// Find first "non-delimiter".
std::string::size_type pos = str.find_first_of("\n", lastPos);
while (std::string::npos != pos || std::string::npos != lastPos)
{
// Found a token, add it to the vector.
records.push_back(str.substr(lastPos, pos - lastPos));
// Skip delimiters. Note the "not_of"
lastPos = str.find_first_not_of("\n", pos);
// Find next "non-delimiter"
pos = str.find_first_of("\n", lastPos);
}
}
Кажется совершенно ненужным повторять весь этот код еще раз для дальнейшего токенизации каждой записи через двоеточие (внутренний разделитель полей) вструктура и толкать каждую структуру в вектор.Я уверен, что есть лучший способ сделать это, или, возможно, дизайн сам по себе неправильный.
Спасибо за любую помощь.