java读取文本文件异常
来源:互联网 发布:电力牵引预算编制软件 编辑:程序博客网 时间:2024/05/21 20:27
今天读取一个文本文件的时候出现一个特殊字符如下图
前面的-复制不出来。复制整个到idea编辑器里面 出现的是
uFEFF20170509
百度搜了一下这个uFEFF 原因如下
在Windows下用文本编辑器创建的文本文件,如果选择以UTF-8等Unicode格式保存,会在文件头(第一个字符)加入一个BOM标识。
这个标识在Java读取文件的时候,不会被去掉,而且String.trim()也无法删除。如果用readLine()读取第一行存进String里面,这个String的length会比看到的大1,而且第一个字符就是这个BOM。
这种情况会造成一些麻烦,比如在读取ini文件的时候,如果想判断第一行是不是以“[”开头就无法正确判断。
幸好,Java在读取Unicode文件的时候,会统一把BOM变成“\uFEFF”,这样的话,就可以自己手动解决了(判断后,用substring()或replace()去除掉这个BOM):
if(line.startsWith("\uFEFF")){ //line = line.substring(1); line = line.replace("\uFEFF", ""); }
什么是BOM?BOM = Byte Order MarkBOM是Unicode规范中推荐的标记字节顺序的方法。比如说对于UTF-16,如果接收者收到的BOM是FEFF,表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little-Endian的。UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明“我是UTF-8编码”。BOM的UTF-8编码是EF BB BF(用UltraEdit打开文本、切换到16进制可以看到)。所以如果接收者收到以EF BB BF开头的字节流,就知道这是UTF-8编码了。
所有的BOM在C/C++/Java中都被处理为”\uFEFF”,参考:http://www.fileformat.info/info/unicode/char/feff/index.htm
Wikipedia关于POM的说明介绍:https://en.wikipedia.org/wiki/Byte_order_mark
(原创文章,转载请注明转自Clement-Xu的博客)
版权声明:本文为原创文章,转载请注明转自Clement-Xu的csdn博客。
- java读取文本文件异常
- Java读取文本文件
- Java 读取文本文件
- Java读取文本文件
- Java读取超大文本文件
- java 读取文本文件 注意
- Java读取文本文件内容
- java读取本地文本文件
- java读取文本文件数据
- Java读取超大文本文件
- java 无损读取文本文件
- java-读取文本文件
- java 读取文本文件
- java文件读取文本文件
- java读取文本文件内容
- java读取大文本文件
- Java按行读取文本文件
- (原创)JAVA文本文件的读取
- 在VS2015上搭建opencv_3.2.0_vc14
- 内核日志:API 及实现
- 划分型循环DP
- Launcher 安装APK快捷方式出现在末尾空白位置
- 微信小程序的app.json配置(二)
- java读取文本文件异常
- Linux安装JDK
- Linux学习之三(根文件系统详解及文件管理mkdir,touch)
- Laravel 下配置 Redis Session
- linux 网络编程---域名解析
- 解决BASE64Encoder类在Eclipse中无法使用问题
- Proguard指南
- TCP标志位-续(RST)
- IOS cellForRowAtIndexPath方法不被调用