STL字符串常用方法扩展

前言



STL作为一个标准模版库,很多容器和算法都是很实用的,接口也相对比较友好,而且在实现上也比较轻量级。相对boost来说,要轻量得多,相对loki来说,使用的模版语法不会那么晦涩难懂,基本还是能看的,相对ATL来说,功能要更通用。

但是STL里面的string,使用过的都知道,很多常用方法没有内置,导致每每使用都会想起CString和AtlString的强大来,而混用这些字符串对象,对于一个有洁癖的程序员来说,往往是很不爽的。在工作过程中,因为有些场景不能使用CString和AtlString,针对STL的string,通过基本函数的方式,实现(积累)了一些常用用法,这里简单分享给大家。

常用方法集

大小写转换

Trim

移除子串

替换子串

StartWith & EndWith

字符串反转

容器字符串连接

字符串分割

代码

/* -------------------------------------------------------------------------
//  文件名      :  QMStlStrUtil.h
//  创建者      :  magic
//  创建时间    :  2015/9/1 17:09:32
//  功能描述    :  STL字符串通用方法(大小写,trim,替换,删除,连接,分割,反转等)
//
//  $Id: $
// -----------------------------------------------------------------------*/
#ifndef __QMSTLSTRUTIL_H__
#define __QMSTLSTRUTIL_H__

#include <string>
#include <numeric>
#include <algorithm>
// -------------------------------------------------------------------------

namespace Util
{

namespace StlStr
{

//////////////////////////////////////////////////////////////////////////
// 字符串大小写转换
//
// -------------------------------------------------------------------------
// 函数     : ToUpperT
// 功能     : 转换成大写
// 返回值   : inline void
// 参数     : std::basic_string<CharT>& s
// 附注     :
// -------------------------------------------------------------------------
template<typename CharT>
inline void ToUpper(std::basic_string<CharT>& s);

template<>
inline void ToUpper(std::basic_string<char>& s)
{
    transform(s.begin(), s.end(), s.begin(), toupper);
}

template<>
inline void ToUpper(std::basic_string<wchar_t>& s)
{
    transform(s.begin(), s.end(), s.begin(), toupper);
}

// -------------------------------------------------------------------------
// 函数     : ToUpperT
// 功能     : 转换成大写
// 返回值   : inline std::basic_string<CharT>
// 参数     : const std::basic_string<CharT>& s
// 附注     : 重载版本,参数为const
// -------------------------------------------------------------------------
template<typename CharT>
inline std::basic_string<CharT> ToUpperT(const std::basic_string<CharT>& s)
{
    std::basic_string<CharT> str(s);
    transform(str.begin(), str.end(), str.begin(), toupper);
    return str;
}

// -------------------------------------------------------------------------
// 函数     : ToLowerT
// 功能     : 转换成小写
// 返回值   : inline void
// 参数     : std::basic_string<CharT>& s
// 附注     :
// -------------------------------------------------------------------------
template<typename CharT>
inline void ToLower(std::basic_string<CharT>& s);

template<>
inline void ToLower(std::basic_string<char>& s)
{
    transform(s.begin(), s.end(), s.begin(), tolower);
}

template<>
inline void ToLower(std::basic_string<wchar_t>& s)
{
    transform(s.begin(), s.end(), s.begin(), tolower);
}

// -------------------------------------------------------------------------
// 函数     : ToLowerT
// 功能     : 转换成小写
// 返回值   : inline std::basic_string<CharT>
// 参数     : const std::basic_string<CharT>& s
// 附注     : 重载版本,参数为const
// -------------------------------------------------------------------------
template<typename CharT>
inline std::basic_string<CharT> ToLowerT(const std::basic_string<CharT>& s)
{
    std::basic_string<CharT> str(s);
    transform(str.begin(), str.end(), str.begin(), tolower);
    return str;
}

//////////////////////////////////////////////////////////////////////////
// 移除字符串前后空白符
//
//////////////////////////////////////////////////////////////////////////
// 空白符枚举
//
// "\0" - NULL
// "\t" - 制表符
// "\n" - 换行
// "\x0B" - 垂直制表符
// "\r" - 回车
// " " - 空格
//
//////////////////////////////////////////////////////////////////////////
// TrimLeft
//
template<typename CharT>
inline void TrimLeft(std::basic_string<CharT>& s);

template<>
inline void TrimLeft(std::basic_string<char>& s)
{
    const char* p = " \t\n\r\x0b";
    s.erase(0, s.find_first_not_of(p));
}

template<>
inline void TrimLeft(std::basic_string<wchar_t>& s)
{
    const wchar_t* p = L" \t\n\r\x0b";
    s.erase(0, s.find_first_not_of(p));
}

template<typename CharT>
inline void TrimLeftEx(std::basic_string<CharT>& s, const std::basic_string<CharT>& charlist);

template<>
inline void TrimLeftEx(std::basic_string<char>& s, const std::basic_string<char>& charlist)
{
    s.erase(0, s.find_first_not_of(charlist));
}

template<>
inline void TrimLeftEx(std::basic_string<wchar_t> &s, const std::basic_string<wchar_t>& charlist)
{
    s.erase(0, s.find_first_not_of(charlist));
}

//////////////////////////////////////////////////////////////////////////
// TrimRight
//
template<typename CharT>
inline void TrimRight(std::basic_string<CharT>& s);

template<>
inline void TrimRight(std::basic_string<char>& s)
{
    const char* p = " \t\n\r\x0b";
    s.erase(s.find_last_not_of(p) + 1);
}

template<>
inline void TrimRight(std::basic_string<wchar_t>& s)
{
    const wchar_t* p = L" \t\n\r\x0b";
    s.erase(s.find_last_not_of(p) + 1);
}

template<typename CharT>
inline void TrimRightEx(std::basic_string<CharT>& s, const std::basic_string<CharT>& charlist);

template<>
inline void TrimRightEx(std::basic_string<char>& s, const std::basic_string<char>& charlist)
{
    s.erase(s.find_last_not_of(charlist) + 1);
}

template<>
inline void TrimRightEx(std::basic_string<wchar_t> &s, const std::basic_string<wchar_t>& charlist)
{
    s.erase(s.find_last_not_of(charlist) + 1);
}

//////////////////////////////////////////////////////////////////////////
// Trim
//
template<typename CharT>
inline void Trim(std::basic_string<CharT>& s);

template<>
inline void Trim(std::basic_string<char>& s)
{
    const char* p = " \t\n\r\x0b";
    s.erase(0, s.find_first_not_of(p));
    s.erase(s.find_last_not_of(p) + 1);
}

template<>
inline void Trim(std::basic_string<wchar_t>& s)
{
    const wchar_t* p = L" \t\n\r\x0b";
    s.erase(0, s.find_first_not_of(p));
    s.erase(s.find_last_not_of(p) + 1);
}

template<typename CharT>
inline void TrimEx(std::basic_string<CharT>& s, const std::basic_string<CharT>& charlist);

template<>
inline void TrimEx(std::basic_string<char>& s, const std::basic_string<char>& charlist)
{
    s.erase(0, s.find_first_not_of(charlist));
    s.erase(s.find_last_not_of(charlist) + 1);
}

template<>
inline void TrimEx(std::basic_string<wchar_t> &s, const std::basic_string<wchar_t>& charlist)
{
    s.erase(0, s.find_first_not_of(charlist));
    s.erase(s.find_last_not_of(charlist) + 1);
}

//////////////////////////////////////////////////////////////////////////
// Erase 删除字符串里面的某个特殊字符
// add by magic 2015/9/7 17:43:10
//
template<typename CharT>
inline void Erase(std::basic_string<CharT>& s, const CharT& chErase);

template<>
inline void Erase(std::basic_string<char>& s, const char& chErase);

template<>
inline void Erase(std::basic_string<wchar_t>& s, const wchar_t& chErase);

template<typename CharT>
void Erase(std::basic_string<CharT>& s, const std::basic_string<CharT>& strErase);

template<>
void Erase(std::basic_string<char>& s, const std::basic_string<char>& strErase);

template<>
void Erase(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& strErase);

//////////////////////////////////////////////////////////////////////////
// Replace 替换子串为另外的子串
//
template<typename CharT>
void Replace(std::basic_string<CharT>& s, const std::basic_string<CharT>& src, const std::basic_string<CharT>& dest);

template<>
void Replace(std::basic_string<char>& s, const std::basic_string<char>& src, const std::basic_string<char>& dest);

template<>
void Replace(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& src, const std::basic_string<wchar_t>& dest);

//////////////////////////////////////////////////////////////////////////
// StartWith & EndWith
//
template<typename CharT>
inline bool StartWith(std::basic_string<CharT>& s, const std::basic_string<CharT>& head);

template<>
inline bool StartWith(std::basic_string<char>& s, const std::basic_string<char>& head)
{
    if (s.size() < head.size())
        return false;

    return (0 == s.compare(0, head.size(), head));
}

template<>
inline bool StartWith(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& head)
{
    if (s.size() < head.size())
        return false;

    return (0 == s.compare(0, head.size(), head));
}

template<typename CharT>
inline bool EndWith(std::basic_string<CharT>& s, const std::basic_string<CharT>& tail);

template<typename CharT>
inline bool EndWith(std::basic_string<char>& s, const std::basic_string<char>& tail)
{
    if (s.size() < tail.size())
        return false;

    return (0 == s.compare(s.size() - tail.size(), tail.size(), tail));
}

template<typename CharT>
inline bool EndWith(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& tail)
{
    if (s.size() < tail.size())
        return false;

    return (0 == s.compare(s.size() - tail.size(), tail.size(), tail));
}

template<typename CharT>
bool StartWithI(std::basic_string<CharT>& s, const std::basic_string<CharT>& head);

template<>
bool StartWithI(std::basic_string<char>& s, const std::basic_string<char>& head);

template<>
bool StartWithI(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& head);

template<typename CharT>
bool EndWithI(std::basic_string<CharT>& s, const std::basic_string<CharT>& tail);

template<>
bool EndWithI(std::basic_string<char>& s, const std::basic_string<char>& tail);

template<>
bool EndWithI(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& tail);

//////////////////////////////////////////////////////////////////////////
// 字符串反转
//
template<typename CharT>
inline void Reverse(std::basic_string<CharT>& s);

template<>
inline void Reverse(std::basic_string<char>& s)
{
    std::reverse(s.begin(), s.end());
}

template<>
inline void Reverse(std::basic_string<wchar_t>& s)
{
    std::reverse(s.begin(), s.end());
}

template<typename CharT>
inline std::basic_string<CharT> Reverse(const std::basic_string<CharT>& s);

template<>
inline std::basic_string<char> Reverse(const std::basic_string<char>& s)
{
    std::basic_string<char> _s(s.rbegin(), s.rend());
    return _s;
}

template<>
inline std::basic_string<wchar_t> Reverse(const std::basic_string<wchar_t>& s)
{
    std::basic_string<wchar_t> _s(s.rbegin(), s.rend());
    return _s;
}

//////////////////////////////////////////////////////////////////////////
// 容器字符串连接
//
template<typename CharT, template<typename S, typename Q = std::allocator<S> > class Container>
inline std::basic_string<CharT> Join(const Container<std::basic_string<CharT> >& c);

template<template<typename S, typename Q = std::allocator<S> > class Container>
inline std::basic_string<char> Join(const Container<std::basic_string<char> >& c)
{
    return std::accumulate(c.begin(), c.end(), std::basic_string<char>());
}

template<template<typename S, typename Q = std::allocator<S> > class Container>
inline std::basic_string<wchar_t> Join(const Container<std::basic_string<wchar_t> >& c)
{
    return std::accumulate(c.begin(), c.end(), std::basic_string<wchar_t>());
}

//////////////////////////////////////////////////////////////////////////
// 字符串分割
//
// -------------------------------------------------------------------------
// 函数     : Split
// 功能     : 分割STL标准字符串
// 返回值   : void
// 参数     : Container<std::basic_string<CharT> >& v 存放分割结果
// 参数     : const std::basic_string<CharT>& s 待分割字符串
// 参数     : const std::basic_string<CharT>& c 分割字符串
// 附注     :
// -------------------------------------------------------------------------
template<typename CharT, template<typename S, typename Q = std::allocator<S> > class Container>
void Split(Container<std::basic_string<CharT> >& v, const std::basic_string<CharT>& s, const std::basic_string<CharT>& c);

template<template<typename S, typename Q = std::allocator<S> > class Container>
void Split(Container<std::basic_string<char> >& v, const std::basic_string<char>& s, const std::basic_string<char>& c)
{
    if (0 == c.length())
        return;

    std::basic_string<char>::size_type pos1 = 0;
    std::basic_string<char>::size_type pos2 = 0;

    pos1 = 0;
    pos2 = s.find(c);
    while (std::basic_string<char>::npos != pos2)
    {
        v.push_back(s.substr(pos1, pos2 - pos1));

        pos1 = pos2 + c.size();
        pos2 = s.find(c, pos1);
    }

    if (pos1 != s.length())
    {
        v.push_back(s.substr(pos1));
    }
}

template<template<typename S, typename Q = std::allocator<S> > class Container>
void Split(Container<std::basic_string<wchar_t> >& v, const std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& c)
{
    if (0 == c.length())
        return;

    std::basic_string<wchar_t>::size_type pos1 = 0;
    std::basic_string<wchar_t>::size_type pos2 = 0;

    pos1 = 0;
    pos2 = s.find(c);
    while (std::basic_string<wchar_t>::npos != pos2)
    {
        v.push_back(s.substr(pos1, pos2 - pos1));

        pos1 = pos2 + c.size();
        pos2 = s.find(c, pos1);
    }

    if (pos1 != s.length())
    {
        v.push_back(s.substr(pos1));
    }
}

} // End Namespace StlStr

} // End Namespace Util

// -------------------------------------------------------------------------
// $Log: $

#endif /* __QMSTLSTRUTIL_H__ */
/* -------------------------------------------------------------------------
//  文件名      :  QMStlStrUtil.cpp
//  创建者      :  magic
//  创建时间    :  2015/9/1 17:09:36
//  功能描述    :
//
//  $Id: $
// -----------------------------------------------------------------------*/

#include "stdafx.h"
#include "QMStlStrUtil.h"

// -------------------------------------------------------------------------

namespace Util
{

namespace StlStr
{

template<>
inline void Erase(std::basic_string<char>& s, const char& chErase)
{
    s.erase(remove_if(s.begin(), s.end(), bind2nd(std::equal_to<char>(), chErase)), s.end());
}

template<>
inline void Erase(std::basic_string<wchar_t>& s, const wchar_t& chErase)
{
    s.erase(remove_if(s.begin(), s.end(), bind2nd(std::equal_to<wchar_t>(), chErase)), s.end());
}

template<>
void Erase(std::basic_string<char>& s, const std::basic_string<char>& strErase)
{
    std::basic_string<char>::size_type pos = 0;
    while (true)
    {
        pos = s.find(strErase, pos);
        if (std::basic_string<char>::npos == pos)
            break;

        s.erase(pos, strErase.size());
    }
}

template<>
void Erase(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& strErase)
{
    std::basic_string<wchar_t>::size_type pos = 0;
    while (true)
    {
        pos = s.find(strErase, pos);
        if (std::basic_string<wchar_t>::npos == pos)
            break;

        s.erase(pos, strErase.size());
    }
}

template<>
void Replace(std::basic_string<char>& s, const std::basic_string<char>& src, const std::basic_string<char>& dest)
{
    std::basic_string<char>::size_type pos = 0;
    while (true)
    {
        pos = s.find(src, pos);
        if (std::basic_string<char>::npos == pos)
            break;

        s.replace(pos, src.size(), dest);
        pos += src.size();
    }
}

template<>
void Replace(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& src, const std::basic_string<wchar_t>& dest)
{
    std::basic_string<wchar_t>::size_type pos = 0;
    while (true)
    {
        pos = s.find(src, pos);
        if (std::basic_string<wchar_t>::npos == pos)
            break;

        s.replace(pos, src.size(), dest);
        pos += src.size();
    }
}

template<>
bool StartWithI(std::basic_string<char>& s, const std::basic_string<char>& head)
{
    if (s.size() < head.size())
        return false;

    std::basic_string<char> _s = s.substr(0, head.size());
    std::basic_string<char> _head = head;
    ToLower(_s);
    ToLower(_head);

    return (0 == _s.compare(0, _head.size(), _head));
}

template<>
bool StartWithI(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& head)
{
    if (s.size() < head.size())
        return false;

    std::basic_string<wchar_t> _s = s.substr(0, head.size());
    std::basic_string<wchar_t> _head = head;
    ToLower(_s);
    ToLower(_head);

    return (0 == _s.compare(0, _head.size(), _head));
}

template<>
bool EndWithI(std::basic_string<char>& s, const std::basic_string<char>& tail)
{
    if (s.size() < tail.size())
        return false;

    std::basic_string<char> _s = s.substr(s.size() - tail.size(), tail.size());
    std::basic_string<char> _tail = tail;
    ToLower(_s);
    ToLower(_tail);

    return (0 == _s.compare(0, _tail.size(), _tail));
}

template<>
bool EndWithI(std::basic_string<wchar_t>& s, const std::basic_string<wchar_t>& tail)
{
    if (s.size() < tail.size())
        return false;

    std::basic_string<wchar_t> _s = s.substr(s.size() - tail.size(), tail.size());
    std::basic_string<wchar_t> _tail = tail;
    ToLower(_s);
    ToLower(_tail);

    return (0 == _s.compare(0, _tail.size(), _tail));
}

} // End Namespace StlStr

} // End Namespace Util
// -------------------------------------------------------------------------
// $Log: $

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-08 22:04:38

STL字符串常用方法扩展的相关文章

【Javascript】JS常用方法扩展

1.格式化字符串操作 String.prototype.format = function(args) { if (arguments.length>0) { var result = this; if (arguments.length == 1 && typeof (args) == "object") { for (var key in args) { var reg=new RegExp ("({"+key+"})"

2018.03.26 Python-Pandas 字符串常用方法

import numpy as np import pandas as pd 1 #字符串常用方法 - strip 2 s = pd.Series([' jack ','jill',' jease ','feank']) 3 df = pd.DataFrame(np.random.randn(3,2),columns=[' Column A',' Column B'],index=range(3)) 4 print(s) 5 print(df.columns) 6 7 print('----')

《ECMAScript 6 入门- 第三章 字符串的扩展》 —— 摘抄

1. codePointAT方法 JavaScript内部,字符以UTF-16的格式储存,每个字符固定为2个字节.对于那些需要 4个字节储存的字符(Unicode编号大于0xFFFF的字符),JavaScript会认为它们是两个字符.ES6提供了codePointAt方 法,能够正确处理4个字节储存的字符,返回一个字符的Unicode编号. codePointAt方法是测试一个字符由两个字节还是由四个字节组成的最简单方法. function is32Bit(c) { return c.codeP

ES6小实验-字符串的扩展

ES6里面的对字符串的扩展实际上就是增加了一些方法,使对字符串的操作更加完善,下面做几个小实验来验证下: includes(): 返回布尔值,表示是否找到了参数字符串,支持第二的参数,表示开始的位置 'use strict'; var s = 'Hello world!'; console.log(s.includes('Hello'));//true startsWith(): 返回布尔值,表示参数字符串是否在源字符串的头部,支持第二的参数,表示开始的位置 'use strict'; var

字符串的扩展

概述 ES6增加了对字符串的扩展. 1.字符串的遍历器接口 ES6为字符串添加了遍历器接口,使得字符串可以被for...of循环遍历. for (let codePoint of 'foo') { console.log(codePoint) } // "f" // "o" // "o" 2.includes(), startsWith(), endsWith() includes():返回布尔值,表示是否找到了参数字符串. startsWith

Javascript读书笔记:字符串常用方法

concat() 连接多个字符串,返回合并后的字符串. 1 var s1="a"; 2 var s2="b"; 3 var s3="c"; 4 5 console.log(s1.concat(s2,s3));//abc 数组中的concat():将参数添加为数组的元素,返回新的数组. 1 var arr = [1, 2, 3]; 2 console.log(arr.concat(4, 5));//[1,2,3,4,5] indexOf() 查找子

字符串转数字扩展方法、字符串处理扩展方法

写代码时喜欢连贯的.链式的写下去,而不是光标再返回到前面写类型转换等等. 自定义了些字符串扩展方法: 1 /// <summary> 2 /// 字符串操作扩展方法类 3 /// </summary> 4 public static class StringOperationExtensions 5 { 6 /// <summary> 7 /// 若输入字符串为null,则返回String.Empty. 8 /// </summary> 9 /// <

3.字符串的扩展

字符串的扩展 字符串的扩展 ES6 加强了对 Unicode 的支持,并且扩展了字符串对象. 字符的 Unicode 表示法 JavaScript 允许采用\uxxxx形式表示一个字符,其中xxxx表示字符的 Unicode 码点. "\u0061" // "a" 但是,这种表示法只限于码点在\u0000~\uFFFF之间的字符.超出这个范围的字符,必须用两个双字节的形式表示. "\uD842\uDFB7" // "??" &

python(4)---字符串常用方法

python字符串常用方法 password='.jpg 123456789 .jpg ABCDFG\n ' #字符串的值不能改变 ##strip()方法 print(password.strip()) #默认去掉字符串两边的空格和换行符 print(password.strip('.jpg')) #去掉两边的.jpg print(password.lstrip()) #掉字符串左边的空格和换行符 print(password.rstrip()) #掉字符串右边的空格和换行符 ##大小写转换 p