微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决使用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"); 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。