码迷,mamicode.com
首页 > 编程语言 > 详细

scala文件读取报错“java.nio.charset.MalformedInputException: Input length = 1”

时间:2018-09-02 13:36:56      阅读:559      评论:0      收藏:0      [点我收藏+]

标签:cep   read   from   for   出现   com   spark   指定   9.png   

今天写spark程序的时候遇到了一个问题就是,读取文件的时候报了一个错:“Exception in thread "main" java.nio.charset.MalformedInputException: Input length = 1”

读取文件的代码如下:

技术分享图片

一看这个这个错“nio”错误,第一感觉就是读文件方法这里出了问题,于是点击去看了一下Source.fromFile这个方法的源码:

技术分享图片

果然,这个方法的重载有好几个,但是每一都直接或间接的需要指定读取文件的编码,就是说你需要以什么编码去读取你需要读取的文件,因为我的IDEA设置的编码时UTF-8

技术分享图片

所以如果使用UTF-8读取GBK文件会出现问题,需要指定读取编码为GBK

技术分享图片

或者

技术分享图片

这两中方式都可以,都是从源码中得来的。

设置完成之后,重新运行程序,报错消失

 

scala文件读取报错“java.nio.charset.MalformedInputException: Input length = 1”

标签:cep   read   from   for   出现   com   spark   指定   9.png   

原文地址:https://www.cnblogs.com/Gxiaobai/p/9573530.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!