![]() |
Platforms, Frameworks & Libraries »
STL »
General
Intermediate
A trim implementation for std::stringBy Rodrigo C F DiasThis article discusses two implementations of the trim function, applied to std::strings. |
VC7, VC7.1, VC8.0, Windows, Visual-Studio, STL, Dev
|
|
Advanced Search Add to IE Search |
|
|
|
||||||||||||||||
The C++ Standard Template Library (STL, for short) provides the handy std::string class, which provides a lot of common string facilities. However, the well-known trim operation was not implemented. The trim operation consists of removing all unused spaces placed before and after the characters into a string. For example, let's say you have a textbox in a program where the user should type their name. Then, the user types the following:
" Rodrigo C Dias "
It would be interesting if you could remove the spaces before and after the name if, for example, you are about to include this string in a database. In this article, we will discuss two easy implementations of trim, both applied to the std::string class.
In this first implementation, the idea is to extract the substring within the string, so we have just what interests. The code is shown below:
void trim1(string& str) { string::size_type pos1 = str.find_first_not_of(' '); string::size_type pos2 = str.find_last_not_of(' '); str = str.substr(pos1 == string::npos ? 0 : pos1, pos2 == string::npos ? str.length() - 1 : pos2 - pos1 + 1); }
Really simple, isn't it?
The second implementation is faster, as you can see yourself if you perform some benchmarks as I did. The idea here is to search the string for the last character before the last space characters. If none is found, then the string is composed only of spaces, so it's completely erased (logical, isn't it?). Else we remove the spaces at the end of the string, based on the found index.
Next step, we search for the first character different from space. Then we remove everything before it. The code of this implementation is shown below:
void trim2(string& str) { string::size_type pos = str.find_last_not_of(' '); if(pos != string::npos) { str.erase(pos + 1); pos = str.find_first_not_of(' '); if(pos != string::npos) str.erase(0, pos); } else str.erase(str.begin(), str.end()); }
This implementation is faster because we have two calls to erase, instead of a string copy (more expensive).
The trim method may be very useful sometimes, and we discussed an implementation of a good one if we are working with the std::string class. Below is the simplest example of how to use it, dealing with the previously given input:
std::string name = " Rodrigo C Dias "; trim2(name);
And that's all.
General
News
Question
Answer
Joke
Rant
Admin
Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+PgUp/PgDown to switch pages.
|
PermaLink |
Privacy |
Terms of Use
Last Updated: 3 Jul 2005 Editor: Smitha Vijayan |
Copyright 2005 by Rodrigo C F Dias Everything else Copyright © CodeProject, 1999-2010 Web09 | Advertise on the Code Project |