字符串查找替换操作

字符串查找

Finder是一个搜索某个容器的任意部分的仿函数,一般无法单独使用。搜索的结果以一个限定所选择的部分的iterator_range的形式给出。常用于函数
find, 
find_format, find_format_copy, 
find_format_all, find_format_all_copy
find_iterator的工厂方法: make_find_iterator, make_split_iterator
find_iterator的构造函数: find_iterator, split_iterator
iter_find, iter_split
[cpp]  view plain copy print ?
  1. namespace boost {  
  2.   namespace algorithm {  
  3.     template<typename RangeT, typename FinderT>  
  4.       iterator_range< typename range_iterator< RangeT >::type >  
  5.       find(RangeT &, const FinderT &);  
  6.   }  
  7. }  
  8.   
  9. template<typename SequenceT, typename FinderT, typename FormatterT>  
  10.   void find_format(SequenceT & Input, FinderT Finder, FormatterT Formatter);  
  11.   
  12. namespace boost {  
  13.   namespace algorithm {  
  14.     template<typename OutputIteratorT, typename RangeT, typename FinderT, typename FormatterT>  
  15.       OutputIteratorT  
  16.       find_format_copy(OutputIteratorT, const RangeT &, FinderT, FormatterT);  
  17.         
  18.     template<typename SequenceT, typename FinderT, typename FormatterT>  
  19.       SequenceT find_format_copy(const SequenceT &, FinderT, FormatterT);  
  20.         
  21.     template<typename SequenceT, typename FinderT, typename FormatterT>  
  22.       void find_format(SequenceT &, FinderT, FormatterT);  
  23.         
  24.     template<typename OutputIteratorT, typename RangeT, typename FinderT, typename FormatterT>  
  25.       OutputIteratorT  
  26.       find_format_all_copy(OutputIteratorT, const RangeT &, FinderT, FormatterT);  
  27.         
  28.     template<typename SequenceT, typename FinderT, typename FormatterT>  
  29.       SequenceT find_format_all_copy(const SequenceT &, FinderT, FormatterT);  
  30.         
  31.     template<typename SequenceT, typename FinderT, typename FormatterT>  
  32.       void find_format_all(SequenceT &, FinderT, FormatterT);  
  33.   }  
  34. }  
  35.   
  36. template<typename SequenceT, typename FinderT, typename FormatterT>  
  37.   void find_format_all(SequenceT & Input, FinderT Finder, FormatterT Formatter);  
  38.   
  39. template<typename OutputIteratorT, typename RangeT, typename FinderT, typename FormatterT>  
  40.   OutputIteratorT  
  41.   find_format_all_copy(OutputIteratorT Output, const RangeT & Input,   
  42.                        FinderT Finder, FormatterT Formatter);  
  43.                          
  44. template<typename SequenceT, typename FinderT, typename FormatterT>  
  45.   SequenceT   
  46.   find_format_all_copy(const SequenceT & Input, FinderT Finder,  
  47.                        FormatterT Formatter);  
  48.   
  49. namespace boost {  
  50.   namespace algorithm {  
  51.     template<typename IteratorT> class find_iterator;  
  52.     template<typename IteratorT> class split_iterator;  
  53.     template<typename RangeT, typename FinderT>  
  54.       find_iterator< typename range_iterator< RangeT >::type >  
  55.       make_find_iterator(RangeT &, FinderT);  
  56.     template<typename RangeT, typename FinderT>  
  57.       split_iterator< typename range_iterator< RangeT >::type >  
  58.       make_split_iterator(RangeT &, FinderT);  
  59.   }  
  60. }  
  61.   
  62. template<typename IteratorT>  
  63. class find_iterator {  
  64. public:  
  65.   // construct/copy/destruct  
  66.   find_iterator();  
  67.   find_iterator(const find_iterator &);  
  68.   template<typename FinderT> find_iterator(IteratorT, IteratorT, FinderT);  
  69.   template<typename FinderT, typename RangeT> find_iterator(RangeT &, FinderT);  
  70.   // public member functions  
  71.   bool eof() const;  
  72.   // private member functions  
  73.   const match_type & dereference() const;  
  74.   void increment();  
  75.   bool equal(const find_iterator &) const;  
  76. };  
  77.   
  78. template<typename IteratorT>  
  79. class split_iterator {  
  80. public:  
  81.   // construct/copy/destruct  
  82.   split_iterator();  
  83.   split_iterator(const split_iterator &);  
  84.   template<typename FinderT> split_iterator(IteratorT, IteratorT, FinderT);  
  85.   template<typename FinderT, typename RangeT>  
  86.     split_iterator(RangeT &, FinderT);  
  87.   // public member functions  
  88.   bool eof() const;  
  89.   // private member functions  
  90.   const match_type & dereference() const;  
  91.   void increment();  
  92.   bool equal(const split_iterator &) const;  
  93. };  
  94.   
  95. template<typename SequenceSequenceT, typename RangeT, typename FinderT>  
  96.   SequenceSequenceT &  
  97.   iter_find(SequenceSequenceT & Result, RangeT & Input, FinderT Finder);  
  98.   
  99. template<typename SequenceSequenceT, typename RangeT, typename FinderT>  
  100.   SequenceSequenceT &  
  101.   iter_split(SequenceSequenceT & Result, RangeT & Input, FinderT Finder); 
在find_iterator与split_iterator上运用的例子
[cpp]  view plain copy print ?
  1. void test_string_finder()  
  2. {  
  3.     using namespace boost;  
  4.   
  5.     // 在find函数中使用  
  6.     std::string strSrc1 = "This is a chair, and that is a desk.";  
  7.     iterator_range<std::string::iterator> ir = find(strSrc1, first_finder("is"));  
  8.   
  9.     // make_find_iterator, find_iterator  
  10.     find_iterator<std::string::iterator> fi1 = make_find_iterator(strSrc1, first_finder("is"));  
  11.     find_iterator<std::string::iterator> fi2 = find_iterator<std::string::iterator>(strSrc1, first_finder("is"));  
  12.     // 有三个is  
  13.     for (fi1; !fi1.eof(); ++fi1)  
  14.     {  
  15.         std::cout << *fi1 << std::endl;  
  16.     }  
  17.   
  18.     // make_split_iterator, split_iterator  
  19.     split_iterator<std::string::iterator> si1 = make_split_iterator(strSrc1, first_finder("is"));  
  20.     split_iterator<std::string::iterator> si2 = split_iterator<std::string::iterator>(strSrc1, first_finder("is"));  
  21.     for (si1; !si1.eof(); ++si1)  
  22.     {  
  23.         std::string str = copy_range<std::string>(*si1);  
  24.         std::cout << *si1 << ": " << str.length() << std::endl;  
  25.     }  
  26. }  

[python]  view plain copy print ?
  1. #include <string>  
  2. #include <iostream>  
  3. #include <algorithm>  
  4. #include <functional>  
  5. #include <boost/algorithm/string/case_conv.hpp>  
  6. #include <boost/algorithm/string/find.hpp>  
  7.   
  8. using namespace std;  
  9. using namespace boost;  
  10.   
  11. int main()  
  12. {    
  13.     cout << "* Find Example *" << endl << endl;  
  14.   
  15.     string str1("abc___cde___efg");  
  16.     string str2("abc");  
  17.   
  18.     // find "cde" substring  
  19.     iterator_range<string::iterator> range=find_first( str1, string("cde") );  
  20.   
  21.     // convert a substring to upper case   
  22.     // note that iterator range can be directly passed to the algorithm  
  23.     to_upper( range );  
  24.   
  25.     cout << "str1 with upper-cased part matching cde: " << str1 << endl;  
  26.   
  27.     // get a head of the string  
  28.     iterator_range<string::iterator> head=find_head( str1, 3 );  
  29.     cout << "head(3) of the str1: " << string( head.begin(), head.end() ) << endl;  
  30.   
  31.     // get the tail  
  32.     head=find_tail( str2, 5 );  
  33.     cout << "tail(5) of the str2: " << string( head.begin(), head.end() ) << endl;  
  34.   
  35.     // char processing  
  36.     char text[]="hello dolly!";  
  37.     iterator_range<char*> crange=find_last(text,"ll");  
  38.   
  39.     // transform the range ( add 1 )  
  40.     transform( crange.begin(), crange.end(), crange.begin(), bind2nd( plus<char>(), 1 ) );  
  41.     // uppercase the range  
  42.     to_upper( crange );  
  43.   
  44.     cout << text << endl;  
  45.   
  46.     cout << endl;  
  47.   
  48.     return 0;  
  49. }  

字符串替换

1、std::String 方法

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

//第一种替换字符串的方法用replace()
void string_replace(string&s1,const string&s2,const string&s3)
{
	string::size_type pos=0;
	string::size_type a=s2.size();
	string::size_type b=s3.size();
	while((pos=s1.find(s2,pos))!=string::npos)
	{
		s1.replace(pos,a,s3);
		pos+=b;
	}
}

//第二种替换字符串的方法用erase()和insert()
void string_replace_2(string&s1,const string&s2,const string&s3)
{
	string::size_type pos=0;
	string::size_type a=s2.size();
	string::size_type b=s3.size();
	while((pos=s1.find(s2,pos))!=string::npos)
	{
		s1.erase(pos,a);
		s1.insert(pos,s3);
		pos+=b;
	}
}
 
 
2、boost库的正则表达式
 #include <stdio.h> 
 
#include <fstream>
#include <sstream>
#include <string>
#include <iterator>
#include <boost/regex.hpp>
#include <fstream>
#include <iostream> 
int main(int argc, char *argv[])
{
printf("Hello, world\n");
std::string in("my is test ! &nbsp;...&nbsp;..&#39;");
boost::regex e1("&#39;");
std::string result = boost::regex_replace(in,e1,"\'", boost::match_default | boost::format_all);
std::cout << result << std::endl;
return 0;

}


3、boost库的字符串相关算法

Erase/Replace

boost把erase和replace函数分开来列了,这样的好处是命名比较清晰,但不好的地方时函数变得非常多,不如重载的形式那么好记。replace的函数有replace_all() 、replace_first()、 replace_last() 以及它们的变体,加上erase,共有20多种,这里就不一一列举了。

cout << replace_all_copy(string("hello world"), "l", "-") << endl;


你可能感兴趣的:(字符串查找替换操作)