C++ 分割字符串两种方法
2017-03-13 14:42
483 查看
原文地址:http://blog.csdn.net/xjw532881071/article/details/49154911
字符串切割的使用频率还是挺高的,string本身没有提供切割的方法,但可以使用stl提供的封装进行实现或者通过c函数strtok()函数实现。
1、通过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)
返回值:子字符串
代码如下:
View Code
2、通过使用strtok()函数实现
原型:char *strtok(char *str, const char *delim);
功能:分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。
描述:strtok()用来将字符串分割成一个个片段。参数s指向欲分割的字符串,参数delim则为分割字符串,当strtok()在参数s的字符串中发现到参数delim的分割字符时 则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s字符串,往后的调用则将参数s设置成NULL。每次调用成功则返回被分割出片段的指针。
其它:strtok函数线程不安全,可以使用strtok_r替代。
代码如下:
字符串切割的使用频率还是挺高的,string本身没有提供切割的方法,但可以使用stl提供的封装进行实现或者通过c函数strtok()函数实现。
1、通过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)
返回值:子字符串
代码如下:
1 std::vector<std::string> splitWithStl(const std::string &str,const std::string &pattern) 2 { 3 std::vector<std::string> resVec; 4 5 if ("" == str) 6 { 7 return resVec; 8 } 9 //方便截取最后一段数据 10 std::string strs = str + pattern; 11 12 size_t pos = strs.find(pattern); 13 size_t size = strs.size(); 14 15 while (pos != std::string::npos) 16 { 17 std::string x = strs.substr(0,pos); 18 resVec.push_back(x); 19 strs = strs.substr(pos+1,size); 20 pos = strs.find(pattern); 21 } 22 23 return resVec; 24 }
View Code
2、通过使用strtok()函数实现
原型:char *strtok(char *str, const char *delim);
功能:分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。
描述:strtok()用来将字符串分割成一个个片段。参数s指向欲分割的字符串,参数delim则为分割字符串,当strtok()在参数s的字符串中发现到参数delim的分割字符时 则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s字符串,往后的调用则将参数s设置成NULL。每次调用成功则返回被分割出片段的指针。
其它:strtok函数线程不安全,可以使用strtok_r替代。
代码如下:
vector<string> split(const string &str,const string &pattern) { //const char* convert to char* char * strc = new char[strlen(str.c_str())+1]; strcpy(strc, str.c_str()); vector<string> resultVec; char* tmpStr = strtok(strc, pattern.c_str()); while (tmpStr != NULL) { resultVec.push_back(string(tmpStr)); tmpStr = strtok(NULL, pattern.c_str()); } delete[] strc; return resultVec; }
相关文章推荐
- hdu 2072 1106学一波字符串分割,C语言与C++两种方法
- 开发JAVA编程中字符串分割的两种方法
- "找出字符串中第一个不重复的字符"和"找出字符串中最后一个重复的字符"的两种方法的C++实现
- C++实现字符串替换的两种方法
- C++常用字符串分割方法(转)
- 开发JAVA编程中字符串分割的两种方法
- C++输入一个字符串,把其中的字符按照逆序输出的两种方法
- C++ 字符串分割方法 实现split
- c/c++ 原生字符串分割简易方法
- C++常用字符串分割方法
- 初学者入门:教你字符串分割的两种方法
- C++ 在尾部添加字符串(两种方法) |C++ 连接字符串
- C++常用字符串分割方法实例汇总
- 字符串分割的两种方法
- 开发JAVA编程中字符串分割的两种方法
- 小例子拾掇知识点之c/c++篇第1话--c分割字符串方法
- C++输入一个字符串,把其中的字符按照逆序输出的两种方法
- C++字符串切割的两种方法
- C++ 拼接字符串的两种方法
- C++常用字符串分割方法实例汇总