我正在尝试执行以下代码片段将文件保存在HDFS中。
Configuration conf = new Configuration();
String targetFileStr = "/someDirectory/fileWith Space.txt"
FileSystem fs = FileSystem.get(URI.create(targetFileStr), conf);
Path path = new Path(targetFileStr);
但是它失败了:java.lang.IllegalArgumentException: Illegal character in path at index 26
at java.net.URI.create(URI.java:852)
我想保留文件名中的空格。 最佳答案
索引26
处有一个非法字符,即它不喜欢路径中的空格。您可以百分比编码特殊字符,例如空格。在这种情况下,请将其替换为%20
。
String targetFileStr = "/someDirectory/fileWith Space.txt"
targetFileStr = targetFileStr.replaceAll(" ","%20");
您也可以使用URLEncoder:String targetFileStr = "/someDirectory/fileWith Space.txt"
targetFileStr = URLEncoder.encode(targetFileStr, "UTF-8");
关于java - 使用Java URI.create在HDFS中用空格写入文件名,导致文件失败,并带有IllegalArgumentException,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/64220969/