首页 > 代码库 > C++中trim去空格函数的实现

C++中trim去空格函数的实现

以下代码摘抄CSDN论坛:

源文连接在:http://topic.csdn.net/u/20110620/10/1e0e91f0-1440-45db-aa29-6ce618fec2da.html

本人目的只在于收藏;

 

C方法:

 1 void del_sp(char *src)    // 删除C风格字符串中的空格 2 { 3     char * fp = src; 4     while (*src) { 5         if (*src !=  ) { // 如果不是空格就复制 6             *fp = *src; 7             fp++; 8         } 9         src++;10     }11     *fp = \0 ; //封闭字符串12 }13 14 void del_sp(string &str)   // 删除string字符串中的空格15 {16     // 因为str.c_str() 是const的,不能直接修改,17     // 所以要复制一个临时的,然后修改后换回去18     char tmp[str.size()+1];19     memcpy(&tmp, str.c_str(), str.size() + 1);20     del_sp(tmp);    // 重载del_sp,调用C风格的函数21     str = tmp;22 }

C++方法:

 1 /********************************************************** 2 * 3 *功能:去前空格 4 * 5 *str:源字符串 6 * 7 *反回值:去除前空格后的字符串 8 * 9 ***********************************************************/10 CUtils::STRING &CUtils::Ltrim(STRING &str)11 {12     str.erase(str.begin(), std::find_if(str.begin(), str.end(),13                                         std::not1(std::ptr_fun(::isspace))));14     return str;15 16 }17 18 /**********************************************************19 *20 *功能:去后空格21 *22 *str:源字符串23 *24 *反回值:去除后空格后的字符串25 *26 ***********************************************************/27 CUtils::STRING &CUtils::Rtrim(STRING &str)28 {29     str.erase(std::find_if(str.rbegin(), str.rend(),30                            std::not1(std::ptr_fun(::isspace))).base(),31               str.end());32     return str;33 34 }35 36 /**********************************************************37 *38 *功能:去前后空格39 *40 *str:源字符串41 *42 *反回值:去除前后空格后的字符串43 *44 ***********************************************************/45 CUtils::STRING &CUtils::Trim(STRING &str)46 {47     return Rtrim(Ltrim(str));48 }

wstring 对象:

如果你是string对象;只需要把wstring转换成string就可以了;

备注:我在处理一个重定向信息时发现并不能去掉文字右边的空格,后来经过分析发现是换行字符作怪;

            这个时候只需要将所有的换行字符转换成空格;在处理即可!

 1 wstring& ::trim2(__IN wstring& str) 2 { 3     wstring::size_type pos = str.find_last_not_of(TEXT( )); 4     if (pos != wstring::npos)  5     { 6         str.erase(pos + 1); 7         pos = str.find_first_not_of(TEXT( )); 8         if(pos != wstring::npos)  9         {10             str.erase(0, pos);11         }12     }13     else 14     {15         str.erase(str.begin(), str.end());16     }17     return str;18 }