Skip to main content

std::string find_first_not_of() method

// (1) Const version only
constexpr size_type find_first_not_of( const basic_string& str, size_type pos = 0 ) const noexcept;

// (2) Const version only
constexpr size_type find_first_not_of( const CharT* s, size_type pos, size_type count ) const;

// (3) Const version only
constexpr size_type find_first_not_of( const CharT* s, size_type pos = 0 ) const;

// (4) Const version only
constexpr size_type find_first_not_of( CharT ch, size_type pos = 0 ) const noexcept;

// (5) Const version only
template < class StringViewLike >
constexpr size_type find_first_not_of( const StringViewLike& t, size_type pos = 0 ) const noexcept(/* see below */);

Finds the first character equal to none of the characters in the given character sequence.
The search considers only the interval [ pos, size() ).

  • (1) Finds the first character equal to none of the characters in str.

  • (2) Finds the first character equal to none of the characters in the range [ s, s + count ).
    This range can include null characters.

  • (3) Finds the first character equal to none of the characters in character string pointed to by s.
    The length of the string is determined by the first null character using Traits::length(s).

  • (4) Finds the first character equal to ch.

  • (5) Implicitly converts t to a string view sv as if by std::basic_string_view<CharT, Traits> sv = t;, then finds the first character equal to none of the characters in sv.

    Overload Resolution

    This overload participates in overload resolution only if std::is_convertible_v<const StringViewLike&, std::basic_string_view<CharT, Traits>> is true and std::is_convertible_v<const StringViewLike&, const CharT*> is false.

Parameters

  • str - string identifying characters to search for
  • pos - position at which to start the search
  • count - length of character string identifying characters to search for
  • s - pointer to a character string identifying characters to search for
  • ch - character to search for
  • t - object (convertible to std::basic_string_view) identifying characters to search for

Return value

Position of the first character of the found substring or npos if no such substring is found.

Complexity

important

This section requires improvement. You can help by editing this doc page.

Exceptions

  • (1-4) (none)
  • (5) noexcept specification:
    noexcept(std::is_nothrow_convertible_v<const T&, std::basic_string_view<CharT, Traits>>)

Notes

Traits::eq() is used for comparison. By default Traits is std::char_traits<CharT>.

Example

#include <string>
#include <iostream>

int main() {
std::string to_search = "Some data with %MACROS to substitute";

std::cout << "Before: " << to_search << '\n';

auto pos = std::string::npos;
while ((pos = to_search.find('%')) != std::string::npos) {
// Permit uppercase letters, lowercase letters and numbers in macro names
const auto after = to_search.find_first_not_of("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789", pos + 1);

// Now to_search[pos] == '%' and to_search[after] == ' ' (after the 'S')

if(after != std::string::npos)
to_search.replace(pos, after - pos, "some very nice macros");
}

std::cout << "After: " << to_search << '\n';
}
Output
Before: Some data with %MACROS to substitute
After: Some data with some very nice macros to substitute
This article originates from this CppReference page. It was likely altered for improvements or editors' preference. Click "Edit this page" to see all changes made to this document.
Hover to see the original license.

std::string find_first_not_of() method

// (1) Const version only
constexpr size_type find_first_not_of( const basic_string& str, size_type pos = 0 ) const noexcept;

// (2) Const version only
constexpr size_type find_first_not_of( const CharT* s, size_type pos, size_type count ) const;

// (3) Const version only
constexpr size_type find_first_not_of( const CharT* s, size_type pos = 0 ) const;

// (4) Const version only
constexpr size_type find_first_not_of( CharT ch, size_type pos = 0 ) const noexcept;

// (5) Const version only
template < class StringViewLike >
constexpr size_type find_first_not_of( const StringViewLike& t, size_type pos = 0 ) const noexcept(/* see below */);

Finds the first character equal to none of the characters in the given character sequence.
The search considers only the interval [ pos, size() ).

  • (1) Finds the first character equal to none of the characters in str.

  • (2) Finds the first character equal to none of the characters in the range [ s, s + count ).
    This range can include null characters.

  • (3) Finds the first character equal to none of the characters in character string pointed to by s.
    The length of the string is determined by the first null character using Traits::length(s).

  • (4) Finds the first character equal to ch.

  • (5) Implicitly converts t to a string view sv as if by std::basic_string_view<CharT, Traits> sv = t;, then finds the first character equal to none of the characters in sv.

    Overload Resolution

    This overload participates in overload resolution only if std::is_convertible_v<const StringViewLike&, std::basic_string_view<CharT, Traits>> is true and std::is_convertible_v<const StringViewLike&, const CharT*> is false.

Parameters

  • str - string identifying characters to search for
  • pos - position at which to start the search
  • count - length of character string identifying characters to search for
  • s - pointer to a character string identifying characters to search for
  • ch - character to search for
  • t - object (convertible to std::basic_string_view) identifying characters to search for

Return value

Position of the first character of the found substring or npos if no such substring is found.

Complexity

important

This section requires improvement. You can help by editing this doc page.

Exceptions

  • (1-4) (none)
  • (5) noexcept specification:
    noexcept(std::is_nothrow_convertible_v<const T&, std::basic_string_view<CharT, Traits>>)

Notes

Traits::eq() is used for comparison. By default Traits is std::char_traits<CharT>.

Example

#include <string>
#include <iostream>

int main() {
std::string to_search = "Some data with %MACROS to substitute";

std::cout << "Before: " << to_search << '\n';

auto pos = std::string::npos;
while ((pos = to_search.find('%')) != std::string::npos) {
// Permit uppercase letters, lowercase letters and numbers in macro names
const auto after = to_search.find_first_not_of("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz"
"0123456789", pos + 1);

// Now to_search[pos] == '%' and to_search[after] == ' ' (after the 'S')

if(after != std::string::npos)
to_search.replace(pos, after - pos, "some very nice macros");
}

std::cout << "After: " << to_search << '\n';
}
Output
Before: Some data with %MACROS to substitute
After: Some data with some very nice macros to substitute
This article originates from this CppReference page. It was likely altered for improvements or editors' preference. Click "Edit this page" to see all changes made to this document.
Hover to see the original license.