字符串分割c,常用字符串分割方法实例汇总数据

2019-05-18 作者:数据库   |   浏览(193)

本文实例汇总了C 常用字符串分割方法,分享给大家供大家参考。具体分析如下:

一、用strtok函数进行字符串分割



我们在编程的时候经常会碰到字符串分割的问题,这里总结下,也方便我们以后查询使用。

原型: char *strtok(char *str, const char *delim);

1、用strtok函数进行字符串分割

一、用strtok函数进行字符串分割

功能:分解字符串为一组字符串。

原型: char *strtok(char *str, const char *delim);

原型: char *strtok(char *str, const char *delim);

参数说明:str为要分解的字符串,delim为分隔符字符串。

功能:分解字符串为一组字符串。

功能:分解字符串为一组字符串。

返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。

参数说明:str为要分解的字符串,delim为分隔符字符串。

参数说明:str为要分解的字符串,delim为分隔符字符串。

其它:strtok函数线程不安全,可以使用strtok_r替代。

返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。

返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。

示例:

其它:strtok函数线程不安全,可以使用strtok_r替代。

其它:strtok函数线程不安全,可以使用strtok_r替代。

 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("%sn",p);
14                 p=strtok(NULL,d);
15         }
16 
17         return 0;
18 }

示例:

示例:

二、用STL进行字符串的分割 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//借助strtok实现split
#include <string.h>
#include <stdio.h>
 
int main()
{
    char s[] = "Golden Global   View,disk * desk";
    const char *d = " ,*";
    char *p;
    p =strtok(s,d);
    while(p)
    {
        printf("%sn",p);
        p=strtok(NULL,d);
    }
 
    return 0;
}
//借助strtok实现split
#include <string.h>
#include <stdio.h>

int main()
{
    char s[] = "Golden Global   View,disk * desk";
    const char *d = " ,*";
    char *p;
    p = strtok(s,d);
    while(p)
    {
        printf("%sn",p);
        p=strtok(NULL,d);
    }

    return 0;
}

涉及到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)
返回值:子字符串

运行效果如下图所示:

2、substr函数 原型:string substr ( size_t pos = 0, size_t n = npos ) const; 功能:获得子字符串。 参数说明:pos为起始位置(默认为0),n为结束位置(默认为npos) 返回值:子字符串 

#include <iostream>

数据库 1

实现如下:

#include <string>

二、用STL进行字符串的分割

 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 pattern.size()-1;
17         }
18     }
19     return result;
20 }

#include <vector>

涉及到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)
返回值:子字符串

数据库 2数据库 3

//字符串分割函数

实现如下:

 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 pattern.size()-1;
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 }

std::vector<std::string> split(std::string str,std::string pattern)

//字符串分割函数
std::vector<std::string> split(std::string str,std::string pattern)
{
  std::string::size_type pos;
  std::vector<std::string> result;
  str =pattern;//扩展字符串以方便操作
  int size=str.size();

  for(int i=0; i<size; i  )
  {
    pos=str.find(pattern,i);
    if(pos<size)
    {
      std::string s=str.substr(i,pos-i);
      result.push_back(s);
      i=pos pattern.size()-1;
    }
  }
  return result;
}

stl完整代码

{

完整代码:

三、用Boost进行字符串的分割

``std::string::size_type pos;

/*
    File   : split1.cpp
    Author  : Mike
    E-Mail  : Mike_Zhang@live.com
 */
#include <iostream>
#include <string>
#include <vector>

//字符串分割函数
std::vector<std::string> split(std::string str,std::string pattern)
{
  std::string::size_type pos;
  std::vector<std::string> result;
  str =pattern;//扩展字符串以方便操作
  int size=str.size();

  for(int i=0; i<size; i  )
  {
    pos=str.find(pattern,i);
    if(pos<size)
    {
      std::string s=str.substr(i,pos-i);
      result.push_back(s);
      i=pos pattern.size()-1;
    }
  }
  return result;
}

int main()
{
  std::string str;
  std::cout<<"Please input str:"<<std::endl;
  //std::cin>>str;
  getline(std::cin,str);
  std::string pattern;
  std::cout<<"Please input pattern:"<<std::endl;
  //std::cin>>pattern;
  getline(std::cin,pattern);//用于获取含空格的字符串
  std::vector<std::string> result=split(str,pattern);
  std::cout<<"The result:"<<std::endl;
  for(int i=0; i<result.size(); i  )
  {
    std::cout<<result[i]<<std::endl;
  }

  std::cin.get();
  std::cin.get();
  return 0;
}

用boost库的正则表达式实现字符串分割 实现如下:

``std::vector<std::string> result;

运行效果如下图所示:

 1 std::vector<std::string> split(std::string str,std::string s)
 2 {
 3         boost::regex reg(s.c_str());
 4         std::vector<std::string> vec;
 5         boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);
 6         boost::sregex_token_iterator end;
 7         while(it!=end)
 8         {
 9                 vec.push_back(*it  );
10         }
11         return vec;
12 }

``str =pattern;``//扩展字符串以方便操作

数据库 4

完整代码:

``int size=str.size();

三、用Boost进行字符串的分割

数据库 5数据库 6

 

用boost库的正则表达式实现字符串分割
实现如下:

 1 //本程序实现的是利用正则表达式对字符串实现分割
 2 //运行环境      VC6.0   boost 库
 3 /*
 4        File      : split2.cpp
 5        Author    : Mike
 6        E-Mail    : Mike_Zhang@live.com
 7 */
 8 #include <iostream>
 9 #include <cassert>
10 #include <vector>
11 #include <string>
12 #include "boost/regex.hpp"
13 
14 std::vector<std::string> split(std::string str,std::string s)
15 {
16         boost::regex reg(s.c_str());
17         std::vector<std::string> vec;
18         boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);
19         boost::sregex_token_iterator end;
20         while(it!=end)
21         {
22                 vec.push_back(*it  );
23         }
24         return vec;
25 }
26 int main()
27 {
28         std::string str,s;
29         str="sss/ddd/ggg/hh";
30         s="/";
31         std::vector<std::string> vec=split(str,s);
32         for(int i=0,size=vec.size();i<size;i  )
33         {
34                 std::cout<<vec[i]<<std::endl;
35         }
36         std::cin.get();
37         std::cin.get();
38         return 0;
39 }

``for``(``int i=0; i<size; i )

std::vector<std::string> split(std::string str,std::string s)
{
    boost::regex reg(s.c_str());
    std::vector<std::string> vec;
    boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);
    boost::sregex_token_iterator end;
    while(it!=end)
    {
        vec.push_back(*it  );
    }
    return vec;
}

Boost完整代码

``{

完整代码:

boost里面有自带的split的函数,如果用boost的话,还是直接用split的好,代码如下:

``pos=str.find(pattern,i);

//本程序实现的是利用正则表达式对字符串实现分割
//运行环境   VC6.0   boost 库
/*
    File   : split2.cpp
    Author  : Mike
    E-Mail  : Mike_Zhang@live.com
*/
#include <iostream>
#include <cassert>
#include <vector>
#include <string>
#include "boost/regex.hpp"

std::vector<std::string> split(std::string str,std::string s)
{
    boost::regex reg(s.c_str());
    std::vector<std::string> vec;
    boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);
    boost::sregex_token_iterator end;
    while(it!=end)
    {
        vec.push_back(*it  );
    }
    return vec;
}
int main()
{
    std::string str,s;
    str="sss/ddd/ggg/hh";
    s="/";
    std::vector<std::string> vec=split(str,s);
    for(int i=0,size=vec.size();i<size;i  )
    {
        std::cout<<vec[i]<<std::endl;
    }
    std::cin.get();
    std::cin.get();
    return 0;
}
 1 #include <iostream>
 2 #include <string>
 3 #include <vector>
 4 #include <boost/algorithm/string/classification.hpp>
 5 #include <boost/algorithm/string/split.hpp>
 6  
 7 using namespace std;
 8  
 9 int main()
10 {
11   string s = "sss/ddd,ggg";
12   vector<string> vStr;
13   boost::split( vStr, s, boost::is_any_of( ",/" ), boost::token_compress_on );
14   for( vector<string>::iterator it = vStr.begin(); it != vStr.end();    it )
15     cout << *it << endl;
16   return 0;
17 }

``if``(pos<size)

运行效果如下图所示:

ps:c中也有对应将包含数的字符串转换为数值:int atoi(const char*);//#include<stdlib.h>

``{

数据库 7

``std::string s=str.substr(i,pos-i);

补充:

``result.push_back(s);

最近发现boost里面有自带的split的函数,如果用boost的话,还是直接用split的好,这里就不多说了,代码如下:

``i=pos pattern.size()-1;

#include <iostream>
#include <string>
#include <vector>
#include <boost/algorithm/string/classification.hpp>
#include <boost/algorithm/string/split.hpp>

using namespace std;

int main()
{
 string s = "sss/ddd,ggg";
 vector<string> vStr;
 boost::split( vStr, s, boost::is_any_of( ",/" ), boost::token_compress_on );
 for( vector<string>::iterator it = vStr.begin(); it != vStr.end();    it )
  cout << *it << endl;
 return 0;
}

``}

希望本文所述对大家的C 程序设计有所帮助。

``}

您可能感兴趣的文章:

  • C 使用WideCharToMultiByte函数生成UTF-8编码文件的方法
  • C 中可正确获取UTF-8字符长度的函数分享
  • C 中汉字字符串的截取
  • C 实现十六进制字符串转换为十进制整数的方法
  • 深入解析C 中的字符数组和处理字符串的方法
  • C字符串与C 字符串的深入理解
  • C 实现strcmp字符串比较的深入探讨
  • C 实现判断字符串是否回文实例解析
  • c 连接两个字符串实现代码 实现类似strcat功能
  • C 实现判断一个字符串是否为UTF8或GBK格式的方法

``return result;

}

 

int main()

{

``std::string str;

``std::cout<<``"Please input str:"``<<std::endl;

``//std::cin>>str;

``getline(std::cin,str);

``std::string pattern;

``std::cout<<``"Please input pattern:"``<<std::endl;

``//std::cin>>pattern;

``getline(std::cin,pattern);``//用于获取含空格的字符串

``std::vector<std::string> result=split(str,pattern);

``std::cout<<``"The result:"``<<std::endl;

``for``(``int i=0; i<result.size(); i )

``{

``std::cout<<result[i]<<std::endl;

``}

 

``std::cin.get();

``std::cin.get();

``return 0;

}
3、find_first_not_of

数据库 8

#include<string>
#include<vector>
#include<iostream>
using namespace std;

void Tokenize(const string& str, vector<string>& tokens, const string& delimiters)
{
  // Skip delimiters at beginning.
  string::size_type lastPos = str.find_first_not_of(delimiters, 0);
  // Find first "non-delimiter".
  string::size_type pos     = str.find_first_of(delimiters, lastPos);
  while (string::npos != pos || string::npos != lastPos)
  {
    // Found a token, add it to the vector.
    tokens.push_back(str.substr(lastPos, pos - lastPos));
    // Skip delimiters.  Note the "not_of"
    lastPos = str.find_first_not_of(delimiters, pos);
    // Find next "non-delimiter"
    pos = str.find_first_of(delimiters, lastPos);
  }
}
int main(int argc, char *argv[])
{
  string str("====aaa==bbb=ccc=ddd====");
  vector<string>tokens;
  Tokenize(str, tokens, "=");
  for( int i = 0; i < tokens.size() ; i   )
  {
    cout << tokens[i] << endl;
  }
  return 0;
}

数据库 9

4、用Boost进行字符串的分割

用boost库的正则表达式实现字符串分割 

#include <iostream>

#include <cassert>

#include <vector>

#include <string>

#include "boost/regex.hpp"

 

std::vector<std::string> split(std::string str,std::string s)

{

``boost::regex reg(s.c_str());

``std::vector<std::string> vec;

``boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);

``boost::sregex_token_iterator end;

``while``(it!=end)

``{

``vec.push_back(*it );

``}

``return vec;

}

int main()

{

``std::string str,s;

``str=``"sss/ddd/ggg/hh"``;

``s=``"/"``;

``std::vector<std::string> vec=split(str,s);

``for``(``int i=0,size=vec.size();i<size;i )

``{

``std::cout<<vec[i]<<std::endl;

``}

``std::cin.get();

``std::cin.get();

``return 0;

}

5、最近发现boost里面有自带的split的函数,如果用boost的话,还是直接用split的好,代码如下:

数据库 10

#include <iostream>
#include <string>
#include <vector>
#include <boost/algorithm/string/classification.hpp>
#include <boost/algorithm/string/split.hpp>
using namespace std;

int main()
{
  string s = "sss/ddd,ggg";
  vector<string> vStr;
  boost::split( vStr, s, boost::is_any_of( ",/" ), boost::token_compress_on );
  for( vector<string>::iterator it = vStr.begin(); it != vStr.end();    it )
  {
    cout << *it << endl;
  }
  return 0;
}

本文由www.bifa365365.com发布于数据库,转载请注明出处:字符串分割c,常用字符串分割方法实例汇总数据

关键词: www.bifa3653