当前位置:首页 > 单片机 > 程序喵大人


如果项目库里集成了boost的话,可以直接使用boost的split功能,我这里也列出了6种实现split的方法,分享一下,希望大家能拓宽下思路。
方法1:stringstream和getline配合使用
std::vector<std::string> stringSplit(const std::string& str, char delim) { std::stringstream ss(str); std::string item; std::vector<std::string> elems; while (std::getline(ss, item, delim)) { if (!item.empty()) { elems.push_back(item); } } return elems;}

方法2:使用std::string::find
std::vector<std::string> stringSplit(const std::string& str, char delim) { std::size_t previous = 0; std::size_t current = str.find(delim); std::vector<std::string> elems; while (current != std::string::npos) { if (current > previous) { elems.push_back(str.substr(previous, current - previous)); } previous = current + 1; current = str.find(delim, previous); } if (previous != str.size()) { elems.push_back(str.substr(previous)); } return elems;}

方法3:使用std::string::find_first_of
std::vector<std::string> stringSplit(const std::string& str, char delim) { std::size_t previous = 0; std::size_t current = str.find_first_of(delim); std::vector<std::string> elems; while (current != std::string::npos) { if (current > previous) { elems.push_back(str.substr(previous, current - previous)); } previous = current + 1; current = str.find_first_of(delim, previous); } if (previous != str.size()) { elems.push_back(str.substr(previous)); } return elems;}

方法4:使用C语言的strtok方法
std::vector<std::string> stringSplit(const std::string& strIn, char delim) { char* str = const_cast<char*>(strIn.c_str()); std::string s; s.append(1, delim); std::vector<std::string> elems; char* splitted = strtok(str, s.c_str()); while (splitted != NULL) { elems.push_back(std::string(splitted)); splitted = strtok(NULL, s.c_str()); } return elems;}

方法5:std::string::find_first_of和std::string::find_first_not_of配合使用
std::vector<std::string> stringSplit(const std::string& str, char delim) { std::vector<std::string> elems; auto lastPos = str.find_first_not_of(delim, 0); auto pos = str.find_first_of(delim, lastPos); while (pos != std::string::npos || lastPos != std::string::npos) { elems.push_back(str.substr(lastPos, pos - lastPos)); lastPos = str.find_first_not_of(delim, pos); pos = str.find_first_of(delim, lastPos); } return elems;}

方法6:使用正则表达式
std::vector<std::string> stringSplit(const std::string& str, char delim) { std::string s; s.append(1, delim); std::regex reg(s); std::vector<std::string> elems(std::sregex_token_iterator(str.begin(), str.end(), reg, -1), std::sregex_token_iterator()); return elems;}
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
关闭