最終更新日時:
が更新

履歴 編集

function
<string>

std::basic_string::replace

basic_string& replace(size_type pos1, size_type n1,
                      const basic_string& str);                     // (1)

basic_string& replace(size_type pos1, size_type n1,
                      const basic_string& str,
                      size_type pos2, size_type n2);                // (2) C++11まで
basic_string& replace(size_type pos1, size_type n1,
                      const basic_string& str,
                      size_type pos2, size_type n2 = npos);         // (2) C++14から

basic_string& replace(size_type pos, size_type n1, const charT* s,
                      size_type n2);                                // (3)
basic_string& replace(size_type pos, size_type n1, const charT* s); // (4)
basic_string& replace(size_type pos, size_type n1, size_type n2,
                      charT c);                                     // (5)

basic_string& replace(iterator i1, iterator i2,
                      const basic_string& str);                     // (6) C++03まで
basic_string& replace(const_iterator i1, const_iterator i2,
                      const basic_string& str);                     // (6) C++11から

basic_string& replace(iterator i1, iterator i2,
                      const charT* s, size_type n);                 // (7) C++03まで
basic_string& replace(const_iterator i1, const_iterator i2,
                      const charT* s, size_type n);                 // (7) C++11から

basic_string& replace(iterator i1, iterator i2,
                      const charT* s);                              // (8) C++03まで
basic_string& replace(const_iterator i1, const_iterator i2,
                      const charT* s);                              // (8) C++11から

basic_string& replace(iterator i1, iterator i2,
                      size_type n, charT c);                        // (9) C++03まで
basic_string& replace(const_iterator i1, const_iterator i2,
                      size_type n, charT c);                        // (9) C++11から

template <class InputIterator>
basic_string& replace(iterator i1, iterator i2,
                      InputIterator j1, InputIterator j2);          // (10) C++03まで
template <class InputIterator>
basic_string& replace(const_iterator i1, const_iterator i2,
                      InputIterator j1, InputIterator j2);          // (10) C++11から

basic_string& replace(const_iterator i1, const_iterator i2,
                      initializer_list<charT> il);                  // (11) C++11から

概要

文字列の一部を置換する。

要件

  • (1) : pos1 <= size()
  • (2) : pos1 <= size()、およびpos2 <= str.size()であること。
  • (3) : pos1 <= size()、および文字配列へのポインタsが、少なくてもn2個の要素を持つ配列を指していること。
  • (4) : pos <= size()、および文字配列へのポインタsが、少なくてもtraits::length(s) + 1個の要素を指す配列を指していること。
  • (6) : [begin(), i1)および[i1, i2)が有効は範囲であること。
  • (7) : [begin(), i1)および[i1, i2)が有効は範囲であること。また、文字配列へのポインタsが、少なくてもn個の要素を持つ配列を指していること。
  • (8) : [begin(), i1)および[i1, i2)が有効は範囲であること。および文字配列へのポインタsが、少なくてもtraits::length(s) + 1個の要素を指す配列を指していること。
  • (9) : [begin(), i1)および[i1, i2)が有効は範囲であること。
  • (10) : [begin(), i1)[i1, i2)、および[j1, j2)が有効は範囲であること。
  • (11) : [begin(), i1)および[i1, i2)が有効は範囲であること。

効果

  • (1) : replace(pos1, n1, str.data(), str.size())を呼び出す。
  • (2) :
    • n2str.size() - pos2のうち小さい方をrlenとする。n == npos の場合は、 str.size() - pos2 が使用される。
    • replace(pos1, n1, str.data() + pos2, rlen)を呼び出す。
  • (3) : n1size() - pos1のうち小さい方をxlenとし、自身のpos1番目からxlen個の要素を、文字配列sの先頭n2文字で置き換える。
  • (4) : replace(pos, n, s, traits::length(s))を呼び出す。
  • (5) : replace(pos1, n1, basic_string(n2, c))と同じ効果を持つ。
  • (6) : replace(i1 - begin(), i2 - i1, str)を呼び出す。
  • (7) : replace(i1 - begin(), i2 - i1, s, n)を呼び出す。
  • (8) : replace(i1 - begin(), i2 - i1, s, traits::length(s))を呼び出す。
  • (9) : replace(i1 - begin(), i2 - i1, basic_string(n, c))を呼び出す。
  • (10) : replace(i1 - begin(), i2 - i1, basic_string(j1, j2))を呼び出す。
  • (11) : replace(i1 - begin(), i2 - i1, il.begin(), il.size())を呼び出す。

戻り値

*this

例外

#include <iostream>
#include <string>

int main()
{
  // (1) 指定した位置からN文字を、文字列で置き換える
  {
    std::string s1 = "12345";
    std::string s2 = "abcde";

    // 1番目から2文字を、s2文字列で置き換える
    s1.replace(1, 2, s2);

    std::cout << "(1) : " << s1 << std::endl;
  }

  // (2) 指定した一からN文字を、文字列の一部で置き換える
  {
    std::string s1 = "12345";
    std::string s2 = "abcde";

    // 1番目から2文字を、s2.substr(2, 3)で置き換える
    s1.replace(1, 2, s2, 2, 3);

    std::cout << "(2) : " << s1 << std::endl;
  }

  // (3) 指定した位置からN文字を、文字配列の先頭M文字で置き換える
  {
    std::string s1 = "12345";

    // 1番目から2文字を、"abcde"の先頭3文字で置き換える
    s1.replace(1, 2, "abcde", 3);

    std::cout << "(3) : " << s1 << std::endl;
  }

  // (4) 指定した位置からN文字を、文字配列で置き換える
  {
    std::string s = "12345";

    s.replace(1, 2, "abcde");

    std::cout << "(4) : " << s << std::endl;
  }

  // (5) 指定した位置からN文字を、M個の文字で置き換える
  {
    std::string s = "12345";

    // 1番目から2文字を、3個の'x'で置き換える
    s.replace(1, 2, 3, 'x');

    std::cout << "(5) : " << s << std::endl;
  }

  // (6) 指定したイテレータ範囲を、文字列で置き換える
  {
    std::string s1 = "12345";
    std::string s2 = "abcde";

    // '2'から'3'をs2で置き換える
    s1.replace(s1.begin() + 1, s1.begin() + 3, s2);

    std::cout << "(6) : " << s1 << std::endl;
  }

  // (7) 指定したイテレータ範囲を、文字配列の先頭N文字で置き換える
  {
    std::string s = "12345";

    // '2'から'3'を、"abcde"の先頭3文字で置き換える
    s.replace(s.begin() + 1, s.begin() + 3, "abcde", 3);

    std::cout << "(7) : " << s << std::endl;
  }

  // (8) 指定したイテレータ範囲を、文字配列で置き換える
  {
    std::string s = "12345";

    s.replace(s.begin() + 1, s.begin() + 3, "abcde");

    std::cout << "(8) : " << s << std::endl;
  }

  // (9) 指定したイテレータ範囲を、N個の文字で置き換える
  {
    std::string s = "12345";

    // '2'から'3'を、3個の'x'で置き換える
    s.replace(s.begin() + 1, s.begin() + 3, 3, 'x');

    std::cout << "(9) : " << s << std::endl;
  }

  // (10) 指定したイテレータ範囲を、他のイテレータ文字範囲で置き換える
  {
    std::string s1 = "12345";
    std::string s2 = "abcde";

    s1.replace(s1.begin() + 1, s1.begin() + 3, s2.begin(), s2.end());

    std::cout << "(10) : " << s1 << std::endl;
  }

  // (11) 指定したイテレータ範囲を、文字の初期化子リストで置き換える
  {
    std::string s = "12345";

    s.replace(s.begin() + 1, s.begin() + 3, {'a', 'b', 'c', 'd', 'e'});

    std::cout << "(11) : " << s << std::endl;
  }
}

出力

(1) : 1abcde45
(2) : 1cde45
(3) : 1abc45
(4) : 1abcde45
(5) : 1xxx45
(6) : 1abcde45
(7) : 1abc45
(8) : 1abcde45
(9) : 1xxx45
(10) : 1abcde45
(11) : 1abcde45

参照