java读取文件乱码
List<String> lines=new ArrayList<String>();
BufferedReader br = new BufferedReader(new FileReader(fileName));
String line = null;
while ((line = br.readLine()) != null) {
lines.add(line);
}
br.close();
Java的I/O类处理如图:
Reader 类是 Java 的 I/O 中读字符的父类,而 InputStream 类是读字节的父类,InputStreamReader 类就是关联字节到字符的桥梁,它负责在 I/O 过程中处理读取字节到字符的转换,而具体字节到字符的解码实现它由 StreamDecoder 去实现,在 StreamDecoder 解码过程中必须由用户指定 Charset 编码格式。值得注意的是如果你没有指定 Charset,将使用本地环境中的默认字符集,例如在中文环境中将使用 GBK 编码。

总结:Java读取数据流的时候,一定要指定数据流的编码方式,否则将使用本地环境中的默认字符集。
public static List<Organ> fileinput() {
// TODO Auto-generated method stub
List<Organ> list = new ArrayList<Organ>();
try {
String fileName = "C://Users/Administrator/Desktop/备份/bustno.txt";
StringBuffer sb = new StringBuffer("");
InputStreamReader sr = new InputStreamReader(new FileInputStream(fileName),"UTF-8");
BufferedReader br = new BufferedReader(sr);
String str = null;
while ((str = br.readLine()) != null) {
String[] firstSplit = str.split("\n");
int recordNum = firstSplit.length;
for(int i=0; i < recordNum;i++){
String[] one = str.split("\\|");
Organ organ = new Organ();
organ.setParentID(0);
organ.setOrganValue(one[0].substring(0, 3));
organ.setOrganName(one[1]);
list.add(organ);
}
}
br.close();
sr.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.print("read succeeded");
return list;
}
list结果集分组:
private static void fenzu(String filepath) throws IOException, ParseException {
// TODO Auto-generated method stub
SimpleDateFormat simpleDate = new SimpleDateFormat("yyyy-MM");
List<String[][]> valueList = new ArrayList<String[][]>();//将结果集转化为二维数组
StringBuffer sb = new StringBuffer("");
InputStreamReader sr = new InputStreamReader(new FileInputStream(filepath),"UTF-8");
BufferedReader br = new BufferedReader(sr);
String str = null;
List<Canal> list = new ArrayList<Canal>();
while ((str = br.readLine()) != null) {
String[] firstSplit = str.split("\n");
int recordNum = firstSplit.length;
for(int i=0; i < recordNum;i++){
String[] one = str.split("\t");
Canal canalone = new Canal();
canalone.setCanal(one[0]);
canalone.setSa_tx_m(one[1]);
canalone.setCr_tx_amt(one[2]);
list.add(canalone);
}}
System.out.print("list size :"+list.size()+ "\n");
//结果集分组
List uniqueList = new ArrayList();//存放Canal个数
for (int j = 0; j < list.size(); j++) {
Canal canal = list.get(j);
if (!uniqueList.contains(canal.getCanal()))
{
System.out.print("uniqueList not contains : " +canal.getCanal().toString() + "\n" );
String[][] b = new String[2][12];//String[0][]为canal,长度为1,String[1][]对应每个月的数值
b[0][0] = canal.getCanal();//canal
String amtValue = list.get(j).getCr_tx_amt();// 金额
Calendar Date = Calendar.getInstance();
Date.setTime(simpleDate.parse(canal.getSa_tx_m()));
int month = Date.get(Calendar.MONTH); // 因为数组的编号要减一,这里不用加一
b[1][month] = amtValue;
uniqueList.add(canal.getCanal());//将canal种类放在集合里
valueList.add(b);//将数值集合放在valueList里
} else {
for (int k = 0; k < valueList.size(); k++) {
String[][] b = valueList.get(k);
if (b[0][0].equals(canal.getCanal())) {
valueList.remove(k);//先remove结果集里不完整的记录
System.out.print("has found canal : " + canal.getCanal() + "\n");
String amtValue = canal.getCr_tx_amt();// 金额
Calendar Date = Calendar.getInstance();
Date.setTime(simpleDate.parse(canal
.getSa_tx_m()));
int month = Date.get(Calendar.MONTH); // 因为数组的编号要减一,这里不用加一
b[1][month] = amtValue.toString();
valueList.add(b);//加了数值再add到分组的list里
break; //找到就返回
}
}
}
}
}
java读取文件乱码的更多相关文章
- java 读取文件乱码
private void filereader() throws IOException{ BufferedReader bf= new BufferedReader(new InputStream ...
- [Java]读取文件方法大全(转)
[Java]读取文件方法大全 1.按字节读取文件内容2.按字符读取文件内容3.按行读取文件内容 4.随机读取文件内容 public class ReadFromFile { /** ...
- 解决 python 读取文件乱码问题(UnicodeDecodeError)
解决 python 读取文件乱码问题(UnicodeDecodeError) 确定你的文件的编码,下面的代码将以'utf-8'为例,否则会忽略编码错误导致输出乱码 解决方案一 with open(r' ...
- Java 读取文件的内容
Java 读取文件的内容 1) CLASS_NAME: 换成自己真实的类名 2) /page/test.json: 换成自己真实的page 3) FileUtils: 来自于org.apache.co ...
- Java读取文件-BufferedReader/FileReader/InputStreamReader/FileInputStream的关系和区别
一.Java读取和存储文件数据流 Java读取文件,实际是将文件中的字节流转换成字符流输出到屏幕的过程 这里面涉及到两个类:InputStreamReader和OutputStreamWriter ...
- Java读取文件时第一行出现乱码“?”问号
我们在使用Java在读取文件(txt.dat等)时,如果文件不是utf-8格式的话,读取结果会出现,中文字符变乱码的情况,所以一般在读取时转为UTF-8格式读取. 但这时会出现一种情况,第一次读取第一 ...
- java 读取文件流
搬运自速学堂:https://www.sxt.cn/Java_jQuery_in_action/ten-iqtechnology.html JAVA中IO流体系: 四大IO抽象类 ·InputStre ...
- java读取中文乱码解决方法
Java读取文本文件(例如csv文件.txt文件等),遇到中文就变成乱码.读取代码如下: List<String> lines=new ArrayList<String>(); ...
- 使用java读取文件夹中文件的行数
使用java统计某文件夹下所有文件的行数 经理突然交代一个任务:要求统计某个文件夹下所有文件的行数.在网上查了一个多小时没有解决.后来心里不爽就决定自己写一个java类用来统计文件的行数,于是花了两个 ...
随机推荐
- Docker for Web Developers目录
在OpenStack在私有云占主导定位之后,后起之秀Docker在PaaS平台.CI/CD.微服务领域展露锋芒.作为Web Developers,我们有必要学习和掌握这门技术. 1. 运行第一个Doc ...
- 学会配置nginx
一.作为一名开发人员,大家可能经常会用到服务器,但是一般线上的服务器可能都是公司公用的,而且线上的服务器一般也不是能随随便便给个人用的,所以部署本地服务器看来是一遍必不可少的事情和能力呀,所以,ngi ...
- Eclipse 配置运行Spark
本文主要记录Spark 在 Eclipse中报 找不到主类的问题.在新建Spark工程,然后add external jars 选择 spark-assembly-1.4.0-hadoop2.6.0. ...
- Java - 双冒泡法排序
最开始的代码 我采用的是我原来进行快速排序所用的方法,一直做不出来. 为什么我会采用原来快速排序的方法?因为我的记忆中好像就是这样的,因此我根据记忆中的快速排序在进行改变,然而,却无法真正的写出双冒泡 ...
- Python算法——二叉树
一.二叉树 from collections import deque class BiTreeNode: def __init__(self, data): self.data = data sel ...
- [DeeplearningAI笔记]改善深层神经网络_深度学习的实用层面1.10_1.12/梯度消失/梯度爆炸/权重初始化
觉得有用的话,欢迎一起讨论相互学习~Follow Me 1.10 梯度消失和梯度爆炸 当训练神经网络,尤其是深度神经网络时,经常会出现的问题是梯度消失或者梯度爆炸,也就是说当你训练深度网络时,导数或坡 ...
- 02_Linux图形界面及文件系统结构介绍
一.根目录 / : 它跟Windows的C.D.E.F不同,在Linux中,所有的文件系统(光驱.U盘.硬盘)都挂载到根目录的某一个文件夹下 bin : 存放二进制可执行文件 sbin ...
- 【linux之文件查看,操作】
一.shell如何处理命令 1.shell会根据在命令中出现的空格字符,将命令划分为多个部分 2.判断第一个字段是内部命令还是外部命令 内部命令:内置于shell的命令(shell builtin) ...
- POJ 1873 The Fortified Forest [凸包 枚举]
The Fortified Forest Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 6400 Accepted: 1 ...
- Ubuntu的Java环境变量
新架构要上线了,这两天开始准备分析一下了,今天是直接进到JAVA_HOME的lib目录执行的java -cp sa-jdi.jar sun.jvm.hotspot.HSDB,然后报了个错: 这是哪来的 ...