当前位置:编程学习 > C/C++ >>

字符串分割(C++)

经常碰到字符串分割的问题,这里总结下,也方便我以后使用。
一、用strtok函数进行字符串分割
原型: char *strtok(char *str, const char *delim);
功能:分解字符串为一组字符串。
参数说明:str为要分解的字符串,delim为分隔符字符串。
返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。
示例:
 1 //借助strtok实现split
 2 #include <string.h>
 3 #include <stdio.h>
 4
 5 int main()
 6 {
 7         char s[] = "Golden Global      View,disk * desk";
 8         const char *d = " ,*";
 9         char *p;
10         p = strtok(s,d);
11         while(p)
12         {
13                 printf("%s\n",p);
14                 p=strtok(NULL,d);
15         }
16
17         return 0;
18 }

 运行效果:

  \

 

二、用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 //字符串分割函数
 2 std::vector<std::string> split(std::string str,std::string pattern)
 3 {
 4         std::string::size_type pos;
 5         std::vector<std::string> result;
 6         str+=pattern;//扩展字符串以方便操作
 7         int size=str.size();
 8
 9         for(int i=0;i<size;i++)
10         {
11                 pos=str.find(pattern,i);
12                 if(pos<size)
13                 {
14                         std::string s=str.substr(i,pos-i);
15                         result.push_back(s);
16                         i=pos;
17                 }
18         }
19         return result;
20 }

完整代码:
  View Code
 1 /*
 2        File      : split1.cpp
 3        Author    : Mike
 4        E-Mail    : Mike_Zhang@live.com
 5 */
 6 #include <iostream>
 7 #include <string>
 8 #include <vector>
 9
10 //字符串分割函数
11 std::vector<std::string> split(std::string str,std::string pattern)
12 {
13         std::string::size_type pos;
14         std::vector<std::string> result;
15         str+=pattern;//扩展字符串以方便操作
16         int size=str.size();
17
18         for(int i=0;i<size;i++)
19         {
20                 pos=str.find(pattern,i);
21                 if(pos<size)
22                 {
23                         std::string s=str.substr(i,pos-i);
24                         result.push_back(s);
25                         i=pos;
26                 }
27         }
28         return result;
29 }
30
31 int main()
32 {
33         std::string str;
34         std::cout<<"Please input str:"<<std::endl;
35         //std::cin>>str;
36         getline(std::cin,str);
37         std::string pattern;
38         std::cout<<"Please input pattern:"<<std::endl;
39         //std::cin>>pattern;
40         getline(std::cin,pattern);//用于获取含空格的字符串
41         std::vector<std::string> result=split(str,pattern);
42         std::cout<<"The result:"<<std::endl;
43         for(int i=0;i<result.size();i++)
44         {
45                 std::cout<<result[i]<<std::endl;
46         }
47
48         std::cin.get();
49         std::cin.get();
50         return 0;
51 }

运行效果:
  \


 

三、用Boost进行字符串的分割
用boost库的正则表达式实现字符串分割补充:软件开发 , C++ ,

CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,