[解決済み] 2つの文字列を、一方が他方を置き換えてしまわないように置き換えるにはどうしたらよいでしょうか?
2022-04-24 18:43:14
質問
例えば、次のようなコードがあるとします。
String word1 = "bar";
String word2 = "foo";
String story = "Once upon a time, there was a foo and a bar."
story = story.replace("foo", word1);
story = story.replace("bar", word2);
このコードが実行された後
story
は次のようになります。
"Once upon a time, there was a foo and a foo."
逆の順番に置き換えても同様の問題が発生します。
String word1 = "bar";
String word2 = "foo";
String story = "Once upon a time, there was a foo and a bar."
story = story.replace("bar", word2);
story = story.replace("foo", word1);
の値は
story
は、次のようになります。
"Once upon a time, there was a bar and a bar."
私の目標は
story
を
"Once upon a time, there was a bar and a foo."
どうすれば実現できるのでしょうか?
どのように解決するのですか?
を使用します。
replaceEach()
メソッドから
Apache Commons StringUtils
:
StringUtils.replaceEach(story, new String[]{"foo", "bar"}, new String[]{"bar", "foo"})
関連
-
[解決済み】JavaでMap値をインクリメントする最も効率的な方法
-
SpringBootApplication を型解決できない。
-
自動配線された依存性のインジェクションに失敗しました。
-
アイデア Springboot Web プロジェクトを jar にパッケージ化する場合、Error: 無効または破損した jarfile x.jar 解決策
-
Javaエラーメッセージがenclosingクラスでない
-
Google Chromeのエラー「Not allowed to load local resource」の解決策について
-
[解決済み] 整数の平方根が整数であるかどうかを判断する最速の方法
-
[解決済み] Javaの "final "キーワードはどのように機能するのでしょうか?(オブジェクトを修正することは可能です。)
-
[解決済み] PHPで文字列の末尾にある3文字を削除するには?
-
[解決済み] mySQLのreplace()を使用して、複数のレコードの文字列を置換するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Java Exceptionが発生しました エラー解決
-
アクセス制限です。タイプ 'Application' は API ではありません。
-
Eclipseで "XXXX "の解決策を(型に)解決することができない
-
eclipseにプロジェクトをインポートした後、Editorにmain typeが含まれない問題
-
eclipse の実行時に java 仮想マシンが見つからなかった
-
java 例外。Javaツールの初期化
-
テストが見つかりませんでした
-
コミットには何も追加されないが、未追跡のファイルが存在し、gitで未追跡のファイルに対する完璧な解決策
-
Maven Pluginの実行がライフサイクル設定の対象外であるエラーの解決
-
[解決済み] 文字列中に出現するすべての文字のインデックス