国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C++ > 正文

C++的字符串分割函數(shù)的使用詳解

2020-05-23 13:59:25
字體:
供稿:網(wǎng)友

經(jīng)常碰到字符串分割的問題,這里總結(jié)下,也方便我以后使用。

一、用strtok函數(shù)進(jìn)行字符串分割

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

功能:分解字符串為一組字符串。

參數(shù)說明:str為要分解的字符串,delim為分隔符字符串。

返回值:從str開頭開始的一個(gè)個(gè)被分割的串。當(dāng)沒有被分割的串時(shí)則返回NULL。

其它:strtok函數(shù)線程不安全,可以使用strtok_r替代。

示例:

//借助strtok實(shí)現(xiàn)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("%s/n",p);        p=strtok(NULL,d);    }    return 0;}

 運(yùn)行效果: c++,分割字符串函數(shù),c++字符串分割

二、用STL進(jìn)行字符串的分割

涉及到string類的兩個(gè)函數(shù)find和substr:

1、find函數(shù)

原型:size_t find ( const string& str, size_t pos = 0 ) const;

功能:查找子字符串第一次出現(xiàn)的位置。

參數(shù)說明:str為子字符串,pos為初始查找位置。

返回值:找到的話返回第一次出現(xiàn)的位置,否則返回string::npos

2、substr函數(shù)

原型:string substr ( size_t pos = 0, size_t n = npos ) const;

功能:獲得子字符串。

參數(shù)說明:pos為起始位置(默認(rèn)為0),n為結(jié)束位置(默認(rèn)為npos)

返回值:子字符串

實(shí)現(xiàn)如下:

//字符串分割函數(shù)std::vector<std::string> split(std::string str,std::string pattern){  std::string::size_type pos;  std::vector<std::string> result;  str+=pattern;//擴(kuò)展字符串以方便操作  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;}

完整代碼:

/*    File   : split1.cpp    Author  : Mike */#include <iostream>#include <string>#include <vector>//字符串分割函數(shù)std::vector<std::string> split(std::string str,std::string pattern){  std::string::size_type pos;  std::vector<std::string> result;  str+=pattern;//擴(kuò)展字符串以方便操作  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;}

運(yùn)行效果:
c++,分割字符串函數(shù),c++字符串分割

三、用Boost進(jìn)行字符串的分割

用boost庫(kù)的正則表達(dá)式實(shí)現(xiàn)字符串分割

實(shí)現(xiàn)如下:

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;}

完整代碼:

//本程序?qū)崿F(xiàn)的是利用正則表達(dá)式對(duì)字符串實(shí)現(xiàn)分割//運(yùn)行環(huán)境   VC6.0 + boost 庫(kù)/*    File   : split2.cpp    Author  : Mike*/#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;}

運(yùn)行效果:
c++,分割字符串函數(shù),c++字符串分割

補(bǔ)充:

最近發(fā)現(xiàn)boost里面有自帶的split的函數(shù),如果用boost的話,還是直接用split的好,這里就不多說了,代碼如下:

#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;}

好,就這些了,希望對(duì)你有幫助。以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 广丰县| 佛坪县| 平阴县| 错那县| 成安县| 海阳市| 吴桥县| 长乐市| 含山县| 资源县| 墨江| 手游| 高淳县| 乾安县| 来安县| 鸡西市| 德州市| 凤凰县| 诸暨市| 新和县| 县级市| 墨脱县| 南岸区| 佛教| 顺昌县| 于田县| 福州市| 宣城市| 苍山县| 绥宁县| 昭通市| 陆丰市| 夏邑县| 内乡县| 缙云县| 泾阳县| 依安县| 乳山市| 昌邑市| 璧山县| 六盘水市|