C++的字符串没有分割函数,因此需要自己写方便使用。而受到开发工具的影响,有很多用起来比较麻烦啦,下面这个比较不错奥。
用STL进行字符串的分割
涉及到string类的两个函数find和substr:
1、find函数
原型:size_t find ( const string& str, size_t pos = 0 ) const;
功能:查找子字符串第一次出现的位置。
参数说明:str为子字符串,pos为初始查找位置。
返回值:找到的话返回第一次出现的位置,否则返回string::npos
2、substr函数
原型:string substr ( size_t pos = 0, size_t n = npos ) const;
功能:获得子字符串。
参数说明:pos为起始位置(默认为0),n为结束位置(默认为npos)
返回值:子字符串
实现如下
- #include <iostream>
- #include <string>
- #include <vector>
- using namespace std;
- //字符串分割函数
- vector<string> split(string str, string pattern)
- {
- string::size_type pos;
- vector<string> result;
- str += pattern;//扩展字符串以方便操作
- int size = str.size();//字符串长度
- for (int i = 0; i<size; i++)
- {
- //pattern是子字符串,i为初始查找位置
- pos = str.find(pattern, i);//找到pattern在str中的位置
- if (pos<size)
- {
- //获取从i到pos-i的子字符串
- string s = str.substr(i, pos - i);
- result.push_back(s);//添加
- //下一个开始查找位置
- i = pos + pattern.size() - 1;
- }
- }
- return result;
- }
- int main()
- {
- string str="I love China is not a";
- string pattern = " ";
- vector<string> result = split(str, pattern);
- cout << "The result:" << endl;
- for (int i = 0; i<result.size(); i++)
- {
- cout << result[i] << endl;
- }
- system("pause");
- return 0;
- }
希望对您有用,上面代码来自:
http://www.cnblogs.com/MikeZhang/archive/2012/03/24/mysplitfuncpp.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请
点击举报。