C++ 处理文件字符常用工具

2016-08-18  本文已影响46人  StoneHeart

1.string

string的定义,初始化,遍历等基础在此略去。

常用的string类型的操作
substr()
replace()
find()
split()
trim()


1.1 substr()

 s.substr(pos,n)该函数截取s字符串从pos开始计算共n个,然后返回该子串。该函数由string类库提供

1.2 replace()

s.replace(pos,len,args)该函数删除s中从下表pos开始的len个字符,用args指定的字符替换。
然后返回s的引用。该函数也由string类库提供

1.3 find()

 s.find(args,pos)该函数从s的pos位置开始查找args第一次出现的位置并返回该值。
 该函数也由string类库提供。

1.4 split()该函数由自己实现

<code>
void split(std::string& s, std::string& delim,std::vector< std::string >* ret)
{
size_t last = 0;
size_t index=s.find_first_of(delim,last);
while (index!=std::string::npos)
{
ret->push_back(s.substr(last,index-last));
last=index+1;
index=s.find_first_of(delim,last);
}
if (index-last>0)
{
ret->push_back(s.substr(last,index-last));
}
}
</code>
1.5 trim()该函数由自己实现
<code>
std::string& trim(std::string &s)
{
if (s.empty())
{
return s;
}
s.erase(0,s.find_first_not_of(" "));
s.erase(s.find_last_not_of(" ") + 1);
return s;
}
</code>

2. vector

定义:

     vector<类型> v;

插入:

     尾部插入: v.push_back(a);
     普通插入:v.insert(v.begin()+i,a);在第i+1个元素前面插入a

删除:

    删除元素:    v.erase(v.begin()+2);删除第3个元
    清空:        v.clear();

遍历:

     使用下标访问元素:
                  cout<<v[0]<<endl;记住下标是从0开始的
     使用迭代器访问元素:
                 vector<int>::iterator it;
                 for(it=v.begin();it!=v.end();it++) 
                     cout<<*it<<endl;

大小:

       向量大小:v.size();

3.map

定义:

   map<类型,类型> m;
   map<int ,string>maplive;
   map<int ,string >::iterator l_it;

查询:

   l_it=maplive.find(112);
   if(l_it==maplive.end())
          cout<<"we do not find112"<<endl;
   else  
          cout<<"wo find112"<<endl;

插入:

    1.maplive.insert(pair<int,string>(102,"aclive"));
    2.maplive.insert(map<int,string>::value_type(321,"hai"));
    3.maplive[112]="April";//map中最简单最常用的插入添加!

删除:

   l_it =maplive.find(112);
   if( l_it == maplive.end())
        cout<<"we do not find112"<<endl;
   else 
        maplive.erase(l_it);//delete 112;

遍历:

  for(l_it=maplive.begin();l_it!=maplive.end();l_it++)
        cout<<"key:"<<l_it->first<<"value:"<<l_it->second<<endl;

大小:

  maplive.size();

4.stack

定义:

      stack<类型> s;
      stack<string> st;

插入:

     string x;
     st.push(x);

删除:

    st.pop();出栈操作只是删除栈顶元素,并不返回该元素。

判空:

    st.empty();

大小:

    st.size();

访问:

   st.top();访问栈顶元素;

5.queue

定义:

   queue<类型> q;
   queue<string>qu;

插入:

  string x;       
  qu.push(x);

删除:

 qu.pop();弹出队列的第一个元素,并不会返回被弹出的元素值;

遍历:

  qu.front() : 访问队首元素
  qu.back() : 访问队尾元素

大小:

  qu.size()

6.文件的输入

<code>
void ReadDataFromFileLBLIntoCharArray()
{
cout<< "逐行读取, 将行读入字符数组, 行之间用回车换行区分" << endl;
ifstream fin("file.txt")
const int LINE_LENGTH=100;
char str[LINE_LENGTH];
while(fin.getline(str,LINE_LENGTH))
{
cout << str << endl;
}
fin.close();
}
</code>

上一篇 下一篇

猜你喜欢

热点阅读