在拿到数据时,目标字符串可能位于一个长字符串(string)中,并用逗号(或其它符号)分隔开,要如何将目标字符串提取出来?
方法一:利用stringstream
for循环遍历string中所有字符,识别到逗号,将其转为空格,再利用istringstream(执行串流的输入操作),读取到空格前后的字符串并输出,详细的可参考以下两篇文章:
1:C++分割带逗号的字符串_九霄星河的博客-优快云博客_c++ 逗号分割字符串
2:C++中的istringstream 的用法_龙在天涯-优快云博客_c++ istringstream
方法二:利用正则表达式
正则表达式是处理字符串很有效的方式,其头文件为 #include <regex> 。
为提取以逗号分隔的字符串,先定义:
# include <regex>
std::regex reg(",");
利用 regex_token_iterator 获取每个子字符串的迭代器:
std::string refferFeatures = "PLN_D1,PLN_D2,PLN_D3,PLN_D4";
std::sregex_token_iterator iter(str.begin(), str.end(), reg, -1); // 获取子字符串迭代器,若参数四改为0,则获取到与reg匹配的字符串迭代器,在本例中即为逗号
decltype(iter) end; // 这里不明白具体含义(看表达式为声明了一个与iter同样类型的变量end,但从上下文语意来看应当是为了获取子字符串尾后迭代器)
for (; iter != end; ++iter)
{
std::cout << iter->str() << " ";
}
输出结果为:
PLN_D1 PLN_D2 PLN_D3 PLN_D4
正则表达式的更多用法,请参考以下链接:
https://www.cnblogs.com/coolcpp/p/cpp-regex.html#:~:text=%E3%80%8C%E6%AD%A3%E5%88%99%E8%A1%A8%E8%BE%BE%E5%BC%8F%E3%80%8D%E5%B0%B1%E6%98%AF%E4%B8%80%E5%A5%97%E8%A1%A8%E7%A4%BA%E8%A7%84%E5%88%99%E7%9A%84%E5%BC%8F%E5%AD%90%EF%BC%8C%E4%B8%93%E9%97%A8%E7%94%A8%E6%9D%A5%E5%A4%84%E7%90%86%E5%90%84%E7%A7%8D%E5%A4%8D%E6%9D%82%E7%9A%84%E6%93%8D%E4%BD%9C%E3%80%82%20std%3A%3Aregex%E6%98%AFC%2B%2B%E7%94%A8%E6%9D%A5%E8%A1%A8%E7%A4%BA%E3%80%8C%E6%AD%A3%E5%88%99%E8%A1%A8%E8%BE%BE%E5%BC%8F%E3%80%8D%EF%BC%88regular,expression%EF%BC%89%E7%9A%84%E5%BA%93%EF%BC%8C%E4%BA%8EC%2B%2B11%E5%8A%A0%E5%85%A5%EF%BC%8C%E5%AE%83%E6%98%AFclass%20std%3A%3Abasic_regex%3C%3E%E9%92%88%E5%AF%B9char%E7%B1%BB%E5%9E%8B%E7%9A%84%E4%B8%80%E4%B8%AA%E7%89%B9%E5%8C%96%EF%BC%8C%E8%BF%98%E6%9C%89%E4%B8%80%E4%B8%AA%E9%92%88%E5%AF%B9wchar_t%E7%B1%BB%E5%9E%8B%E7%9A%84%E7%89%B9%E5%8C%96%E4%B8%BAstd%3A%3Awregex%E3%80%82
864

被折叠的 条评论
为什么被折叠?



