
JAVA初心者です。
javaのStringクラスについての質問です。
ファイルパス「C:\\Test\\Out\\test.txt」
が入っているString変数w_Filenameの
「\\」を「\」にreplaceしてファイル出力したいのですが、
w_Filename.replaceAll("\\\\","\\")
とやると、
java.lang.StringIndexOutOfBoundsException: String index out of range: 1
とエラーになってしまいます。
どうしたらいいのでしょうか?教えてください。
No.3ベストアンサー
- 回答日時:
前の回答では「replaceAll メソッドがこの例外を投げるはずはありません」と書きましたが、実際はそうでもないようです。
API仕様ドキュメントを注意深く読むと、置換する文字列においてバックスラッシュはエスケープ文字として扱われることと、IndexOutOfBoundsExceptionがスローされる可能性があることがかなり遠回しに書いてあります。(私も最初は気づきませんでした)
それに従うと、replaceAllメソッドに与える引数の2番目は、\ ではなく \\ となりますので、それをソースコート上で表すには "\\" ではなく "\\\\" とすることになります。
結局、
replaceAll("\\\\\\\\", "\\\\");
が正解のようです。
回答、ありがとうございます。
無事、教えていただいた方法でできました。
初心者の私にもわかりやすく、なぜそうなるかまで説明していただいて、本当に感謝いたします。
じっくりしくみを理解しながらプログラム作成する大切さも教えていただいた気がします。
ありがとうございました!!
No.2
- 回答日時:
w_Filename.replaceAll("\\\\","\\")
じゃなくて
w_Filename.replaceAll("\\\\\\\\","\\")
ですね。
前者では文字列中の一つのバックスラッシュを一つのバックスラッシュに置換するだけで、結局何も変わりません。
二つのバックスラッシュ文字を表す正規表現は
\\\\
です。それをソースコード中の文字列として表すには、
"\\\\\\\\"
とする必要があります。
ところで、StringIndexOutOfBoundsException はどこで発生していますか? replaceAll メソッドがこの例外を投げるはずはありません。おそらく、StringIndexOutOfBoundsException は replaceAll とは無関係です。
親切な回答、どうもありがとうございました。
色々なことが間違えているかもしれません。。。
理解もしないで質問をしてすいませんでした。
ちなみに、エラーメッセージの上5行は以下の通りでした。もう少し勉強します。ありがとうございました。
java.lang.StringIndexOutOfBoundsException: String index out of range: 1
at java.lang.String.charAt(String.java:444)
at java.util.regex.Matcher.appendReplacement(Matcher.java:551)
at java.util.regex.Matcher.replaceAll(Matcher.java:661)
at java.lang.String.replaceAll(String.java:1663)
No.1
- 回答日時:
何をしたいのか,今ひとつ解りませんが
\ はエスケープコードといって特殊なコードです
ソース上では "\\" となっていますが
コンパイルすると "\" の1文字に変換されます
なので
「C:\\Test\\Out\\test.txt」を
「C:\Test\Out\test.txt」と変えると
「C:(TAB)est(??)ut(TAB)est.txt」
\T , \t : TAB 0x09
\O : ないので NUL? 0x00
となってしまい,エラーになります
意味のわからない質問にわざわざ回答いただき、どうもありがとうございました。
エスケープは分かっているつもりだったのですが、理解不十分だと再認識しました。また、勉強しなおします。ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAでファイル名を指定して保存するとき 4 2023/03/26 21:55
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) 集めたシートのシート名を変更したい。 下記のコードでサブフォルダにあるファイルのSheet3を集めて 6 2022/08/23 10:38
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/07/03 09:11
- Visual Basic(VBA) 入力ボックスが繰り返しポップアップして止まらない。 下記コードでファイル名の変更をしたいのですが、変 1 2022/09/08 11:27
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/09 10:33
- Excel(エクセル) エクセルVBA、間違っているコード内容を正して頂けませんか? エクセルワークシートに納品書を作ったの 2 2023/08/02 21:13
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「タイプ初期化子が例外をスロ...
-
時間の取得
-
try catchについて
-
JSPからのパラメータチェック
-
例外処理の作法
-
全角スペースのチェックについて
-
nullで、return出来るのはどん...
-
C#の捕捉されない例外処理の対...
-
threadの中でのメモリ??
-
ファイルダイアログを開いた時...
-
カンマ付数字をDBへ追加する...
-
数字か文字列かを判定する関数
-
JSPからServletへの値の引渡し
-
LISPで例外を発生させるには?
-
Timestamp型への変換について(J...
-
VB.Net Object型 空かどうか
-
VBA Evaluate関数 型が一致しま...
-
VC++におけるCStringの変換
-
【JAVA】与えられた金額を貨幣...
-
連続する「\\」をひとつの「\\...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「タイプ初期化子が例外をスロ...
-
VB.Net Object型 空かどうか
-
数字か文字列かを判定する関数
-
VBA Evaluate関数 型が一致しま...
-
【JAVA】与えられた金額を貨幣...
-
VC++におけるCStringの変換
-
連続する「\\」をひとつの「\\...
-
文字列からダブルクオートの削除
-
C#の捕捉されない例外処理の対...
-
ファイルダイアログを開いた時...
-
C# マルチスレッドにおける例外...
-
0除算の例外処理ができない!!...
-
時間の取得
-
Timestamp型への変換について(J...
-
例外ってIf文の中に入れますか...
-
Excelでのエラー
-
文字列が数字のみで構成されて...
-
VB.NETで16進数が正しいかどう...
-
String型の日付(2005/11/25)の...
-
VBA 400エラー 1004エラー
おすすめ情報