很多其他语言的libary都会有去除string类的首尾空格的库函数,但是标准C++的库却不提供这个功能。但是C++string也提供很强大的功能,实现trim这种功能也不难。下面是几种方法:

1.使用string的find_first_not_of,和find_last_not_of方法

  1. /*
  2. Filename : StringTrim1.cpp
  3. Compiler : Visual C++ 8.0
  4. Description : Demo how to trim string by find_first_not_of & find_last_not_of
  5. Release : 11/17/2006
  6. */
  7. #include <iostream>
  8. #include <string>
  9. std::string& trim(std::string &);
  10. int main()
  11. {
  12. std::string s = " Hello World!! ";
  13. std::cout << s << " size:" << s.size() << std::endl;
  14. std::cout << trim(s) << " size:" << trim(s).size() << std::endl;
  15. return 0;
  16. }
  17. std::string& trim(std::string &s)
  18. {
  19. if (s.empty())
  20. {
  21. return s;
  22. }
  23. s.erase(0,s.find_first_not_of(" "));
  24. s.erase(s.find_last_not_of(" ") + 1);
  25. return s;
  26. }

2.使用boost库中的trim,boost库对提供很多C++标准库没有但是又非常常用和好用的库函数,例如正则表达式,线程库等等。

  1. /*
  2. Filename : boostStringTrim.cpp
  3. Compiler : Visual C++ 8.0 / ISO C++ (boost)
  4. Description : Demo how to boost to trim string
  5. Release : 02/22/2007 1.0
  6. */
  7. #include <iostream>
  8. #include <string>
  9. #include <boost/algorithm/string.hpp>
  10. using namespace std;
  11. using namespace boost;
  12. int main() {
  13. string s = " hello boost!! ";
  14. trim(s);
  15. cout << s << endl;
  16. }

3.使用template(我用GCC编译不通过,用VS2005却可以)

  1. /*
  2. Filename : stringTrim1.cpp
  3. Compiler : Visual C++ 8.0
  4. Description : Demo how to trim string by other method.
  5. Release : 11/18/2006
  6. */
  7. #include <string>
  8. #include <iostream>
  9. #include <cwctype>
  10. template <class T>
  11. std::basic_string<T>& trim(std::basic_string<T>&);
  12. int main( )
  13. {
  14. std::string s = " Hello World!! ";
  15. std::cout << s << " size:" << s.size() << std::endl;
  16. std::cout << trim(s) << " size:" << trim(s).size() << std::endl;
  17. return 0;
  18. }
  19. template <class T>
  20. std::basic_string<T>& trim(std::basic_string<T>& s)
  21. {
  22. if (s.empty()) {
  23. return s;
  24. }
  25. std::basic_string<T>::iterator c;
  26. // Erase whitespace before the string
  27. for (c = s.begin(); c != s.end() && iswspace(*c++);); s.erase(s.begin(), --c);
  28. // Erase whitespace after the string
  29. for (c = s.end(); c != s.begin() && iswspace(*--c);); s.erase(++c, s.end());
  30. return s;
  31. }

split方法

  1. //注意:当字符串为空时,也会返回一个空字符串
  2. void split(std::string& s, std::string& delim,std::vector< std::string >* ret)
  3. {
  4. size_t last = 0;
  5. size_t index=s.find_first_of(delim,last);
  6. while (index!=std::string::npos)
  7. {
  8. ret->push_back(s.substr(last,index-last));
  9. last=index+1;
  10. index=s.find_first_of(delim,last);
  11. }

[转]C++ string的trim, split方法的更多相关文章

  1. String类的split方法以及StringTokenizer

    split方法可以根据指定的表达式regex将一个字符串分割成一个子字符串数组. 它的参数有两种形式,也即:split(String regex)和split(String regex, int li ...

  2. java中String对象的split方法

    在java.lang包中有String.split()方法,返回是一个String[]数组,今天碰到一个自己没注意的问题: 1.特殊分隔符 String str1 = "123|456|78 ...

  3. java基础---->String中的split方法的原理

    这里面主要介绍一下关于String类中的split方法的使用以及原理. split函数的说明 split函数java docs的说明: When there is a positive-width m ...

  4. 【Java面试题】17 如何把一个逗号分隔的字符串转换为数组? 关于String类中split方法的使用,超级详细!!!

    split 方法:将一个字符串分割为子字符串,然后将结果作为字符串数组返回. stringObj.split([separator],[limit])参数:stringObj   必选项.要被分解的 ...

  5. JAVA中string类的split方法

    split([separator,[limit]])第一个参数为分隔符,可以是一个正则表达式,第二个参数为返回结果数组的长度

  6. String.split()方法你可能不知道的一面

    一.问题 java中String的split()是我们经常使用的方法,用来按照特定字符分割字符串,那么我们看以下一段代码: public void splitTest() { String str = ...

  7. String的split方法,你真的懂吗

    String的split方法相信大家都不陌生,或多或少都用过它将字符串转成一个数组,但是就是这样一个简单的方法,里面也有一个不得不注意.不深不浅的小坑. 本地测试代码如下图所示: 图1 大家会发现sp ...

  8. 自己实现String.prototype.trim方法

    今天呢 知乎看到一道题 说是网易面试题,要求自己写一个trim()方法, 实现 var str = "   a   sd  "; 去掉字符串两端的空格. 直接上码 var str ...

  9. C# String.split()用法小结。String.Split 方法 (String[], StringSplitOptions)

    split()首先是一个分隔符,它会把字符串按照split(' 字符')里的字符把字符串分割成数组,然后存给一个数组对象. 输出数组对象经常使用foreach或者for循环. 第一种方法 string ...

随机推荐

  1. 电赛总结(二)——AD之STM32F102ZE单片机自带12位AD

    直接上程序即可 #ifndef __ADC_H #define __ADC_H #include "stm32f10x.h" #include "LCD3.2.h&quo ...

  2. Xamarin Android长度单位区别

    Xamarin Android长度单位区别 Android中长度单位有6种:px.in.mm.pt.dp/dip.sp.其中,px表示显示设备的一个像素:in表示显示设备的1英寸:mm表示显示设备的1 ...

  3. POJ2553 The Bottom of a Graph(强连通分量+缩点)

    题目是问,一个有向图有多少个点v满足∀w∈V:(v→w)⇒(w→v). 把图的强连通分量缩点,那么答案显然就是所有出度为0的点. 用Tarjan找强连通分量: #include<cstdio&g ...

  4. python 代码片段5

    #coding=utf-8 # python 有两个主要数据类型:int和float.根据Kiss原则,python只有一宗整数类型int. print 3**3 print int('123') p ...

  5. BZOJ1100 : [POI2007]对称轴osi

    将多边形转化为如下的环: 1到2的边,角2,2到3的边,角3,...,n-1到n的边,角n,n到1的边,角1 然后枚举对称轴,如果i是对称轴,那么[i-n,i+n]是一个回文串 用Manacher算法 ...

  6. BZOJ3738 : [Ontak2013]Kapitał

    $C_{N+M}^N=\frac{(N+M)!}{N!M!}$ 考虑求出$ans\bmod 10^9$的值 $10^9=2^9\times5^9$ 以$2^9$为例,先预处理出$1$..$2^9$中不 ...

  7. BZOJ3755 : Pty爬山

    l[i],r[i]表示站在i点往左往右走能看到的最高峰,用栈维护凸壳求出 h[i]表示i点能看到的最高峰的高度 a[i],b[i]表示i点往左往右走时反悔的点,即第一个h[j]>h[i]的j,用 ...

  8. 蒟蒻修养之tc蓝名计划

    开一个新坑......(听说tc是智商高的人才能玩的QAQ显然我是被屠的... 1 [645DIV2]这个能说是裸模拟吗... 弃坑= =做了一些题感觉没必要放上来了= =等div1先吧....... ...

  9. requirejs模块化框架用法分享

      我采用的是一个非常流行的库require.js. 一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一 ...

  10. git 用Gitk /usr/bin/which: no wish

    /usr/bin/which: no wish 安装yum -y install tcl 和yum -y install tk 显示所有的分支 $gitk --all 显示所有的分支 $gitk -- ...