java download csv (utf-8)文件用excell打开乱码的问题,我在网上搜了很久,一直没有找到解决方案,曾经在javaeye 上看到过一篇文章关于加上BOM标记的文章
http://yvonxiao.iteye.com/blog/564461 试验下来根本不解决问题。
首先来看一下问题:
我的测试环境使用的是excell 2003 经过测试 阅读csv文件根本不认识UTF-8编码,测试过程是这样的:
【1】excell编辑保存一份csv文件
【2】用notepad开打,可以看到他的是ANSI编码格式保存的.
【3】用IE打开可以看到他的编码是GB2312.
以上说明至少在我的xp的机器上excell能认出GB2312编码方式存放的csv文件。
【4】用notepad把这份文件另存为UTF-8格式(注意windows自带的notepad存为utf-8是带有bom),然后用excell打开,结果是乱码
以上说明至少在我的机器上excell不认识UTF-8带BOM的csv文件
【5】用notepad++去掉bom标示保存后 excell打开依然是乱码
以上说明至少在我的机器上excell不认识UTF-8不带BOM的csv文件
那么如果才能保存让excell2003认识的csv文件呢,最简单的方式就是保存和步骤【3】一样的文件格式!
【1】在c://temp 目录下建立utf-8编码的文件:
我爱,中国
【2】运行如下程序
public static void main(String[] args) throws IOException {
Properties properties = System.getProperties();;
System.out.println(properties.getProperty("file.encoding"));
String in =FileUtils.readFileToString(new File("C:\\temp\\test.txt"), "UTF-8");
byte[] aa=in.getBytes();
byte[] bb ;
//EF BB BF
if (Bytes2HexString(aa,0,2).equals("EFBBBF")){
System.out.println("BOM");
bb=Arrays.copyOfRange(aa, 3, aa.length);
}else{
bb=aa;
}
//FileUtils.writeByteArrayToFile(new File("C:\\temp\\test2312.txt"), new String (bb,"GB2312");)
FileUtils.writeStringToFile(new File("C:\\temp\\test2312.csv"), new String (bb,"UTF-8"),"GB2312");
}
public static String Bytes2HexString(byte[] b,int start ,int end) {
String ret = "";
if (end >=b.length) end=b.length;
for (int i = start; i <= end; i++) {
String hex = Integer.toHexString(b[i] & 0xFF);
if (hex.length() == 1) {
hex = '0' + hex;
}
ret += hex.toUpperCase();
}
return ret;
}
最后用excell开打test2312文件 一切正常。
分析:
无论是用struts还是数据库取出的数据,首先要了解数据来源的编码,这个例子数据来源的编码是utf-8格式的。
最后写文件文件的时候excell认csv文件的时候之人ansi编码的,中文可以用GB2312,日文和韩文的话你要自己查一下别人机器上支持的编码。
附上一篇讲解编码的非常好的好文章:
http://www.regexlab.com/zh/encoding.htm
分享到:
相关推荐
python开发所需要的资源已经打包,根据书籍目录的章节,大家如果需要天气的csv文件,可以在16章找到。
鸢尾花数据集 约150条数据,每条样本4个属性,共3个类别
R语言记号体系所用的数据。
csv下载 一个简单的Web组件,用于将数组(或类似数组的对象)数组下载为CSV文件。 它扩展了元素。 演示版 安装 使用安装组件: $ bower install csv-... a is =" csv-download " data =" {{someArray}} " download =
骑自行车的女孩,flash源文件。
csv转换xls文件程序 可自定义csv分隔符
目标检测中CSV格式转XML格式
该程序为可执行文件,功能是将某个目录下的xls或xlsx文件全部转化为csv文件,源码为:http://download.csdn.net/download/zonelza3/4144850,但由于这位朋友的源码会与WIN的SDK重定义Font类,所以导致编译不过,我修改了...
对于那些从此处开始使用Machine Learning并希望应用各种算法的人来说,这是一个基本的汽车数据集。 auto-mpg.csv
order.csv是K-Means聚类算法使用到的数据集,通过K-Means聚类算法可以实现对于order.csv中的数据按照聚类中心进行聚类
CSV文件操作 ----------C#.Net实例代码
hr:小时 (0 to 23) (只在 hour.csv 有,作业忽略此字段) holiday:是否是节假日 weekday:星期中的哪天,取值为 0~6 workingday:是否工作日 1=工作日 (非周末和节假日) 0=周末 weathersit:天气 1:...
插件支持jmeter像loadrunner一样自定义参数化取值方法,与loadrunner一样支持,Sequential、Unique和Random;支持Each Iteration和Once;插件来着github; Jmeter 版本 5.2.1 或更高版本 Java 8 或更高版本
世界新冠肺炎数据集,csv格式230000条数据, 属性包括: continentName continentEnglishName countryName countryEnglishName provinceName provinceEnglishName province_zipCode province_confirmedCount ...
数据集
Spring Boot 定时通过sftp 从linux服务器下载.csv文件,读取文件,并写入数据库
LMI公司线激光扫描仪 Gocator格式转换工具,可将扫描txt、stl、obj等点云数据转换为csv格式。
世界电量载荷
鸢尾花数据集