使用Java URI.create在HDFS中用空格写入文件名,导致文件失败,并出现IllegalArgumentException

问题描述

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