我正在尝试执行以下代码片段将文件保存在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/

10-13 02:41