Unicode を使用して文字列データをエンコードすると、非 ASCII 文字を含む幅広い文字を表現できます。ただし、さまざまな理由により、エスケープされた Unicode 文字 (uXXXX) を含む文字列を通常の Unicode 文字の文字列に変換する必要がある場合があります。
このシナリオでは、ファイル名が読み取られるという問題が発生します。ファイル内の文字列は Unicode エンコードでエスケープされます。これにより、検索条件にエスケープ文字が含まれ、一致が失敗するため、ファイルの検索時に問題が生じます。
この問題に対処するには、Apache Commons Lang StringEscapeUtils.unescapeJava() メソッドを利用するのが効果的な解決策の 1 つです。 。このメソッドは、エスケープされた Java 文字列をデコードし、エスケープされていない同等の文字列に変換するように設計されています。
次のコード スニペットは、エスケープされた Unicode 文字列をデコードするための StringEscapeUtils.unescapeJava() の使用法を示しています。
import org.apache.commons.lang.StringEscapeUtils; public class UnicodeStringConverter { public static void main(String[] args) { String sJava = "\u0048\u0065\u006C\u006C\u006F"; // Decode the escaped Unicode string String unescapedString = StringEscapeUtils.unescapeJava(sJava); // Print the unescaped string System.out.println("Unescaped String: " + unescapedString); } }
この例では、エスケープされた Unicode 文字列が sJava 変数に保存されます。 StringEscapeUtils.unescapeJava() メソッドを使用して文字列をデコードすると、エスケープされていないバージョンが unescapedString 変数に格納されます。最後に、エスケープされていない文字列がコンソールに出力されます。
以上がJava ファイル名内のエスケープされた Unicode 文字をデコードするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。