java读取txt文本中如含有中文,可能会出现乱码,解决方案是:
1.要统一编码,java工程的编码,txt文本编码,java工程中的java文本编码都统一为utf-8;
利用 InputStreamReader(new FileInputStream(fileUrl), “utf-8”)将文本再次设置为utf-8
//1从源文件中逐行读,然后逐行写入目标文件
public static void fileCopyByLine1(String sourceFileName,String destFileName){
File f=new File(sourceFileName);
File i=new File(destFileName);
BufferedReader br=null;
BufferedWriter bw=null;
String str="";
try{
br=new BufferedReader(new InputStreamReader(new FileInputStream(f),"utf-8"));
bw=new BufferedWriter(new OutputStreamWriter(new FileOutputStream(i),"utf-8"));
while((str=br.readLine())!=null){
bw.write(str);
bw.newLine();
}
bw.flush();
}catch(FileNotFoundException e){
e.printStackTrace();
System.out.println("未找到文件!");
}catch(IOException e){
e.printStackTrace();
System.out.println("读写错误!");
}finally{
try{
if(bw!=null) bw.close();
}catch(IOException e){
e.printStackTrace();
System.out.println("关闭包装目标文件失败!");
}
try{
if(br!=null) br.close();
}catch(IOException e){
e.printStackTrace();
System.out.println("关闭包装源文件失败!");
}
}
}
2.由于字节流以字节为单位获取数据,识别中文字符时会出现乱码,而字符流采用Unicode编码,可转换字符集,故用字符流如FileReader,FileWriter获取文本数据。
//2从源文件中逐字符读,然后逐字符写入目标文件
public static void fileCopyByChar(String sourceFileName,String destFileName){
FileReader fr=null;
FileWriter fw=null;
int len=0;
char []str=new char[1024];
try{
fr=new FileReader(sourceFileName);
fw=new FileWriter(destFileName);
while((len=fr.read(str))!=-1){
fw.write(str, 0, len);
}
}catch(FileNotFoundException e){
e.printStackTrace();
System.out.println("未找到文件!");
}catch(IOException e){
e.printStackTrace();
System.out.println("读写错误!");
}
finally{
try{
if(fw!=null) fw.close();
}catch(IOException e){
e.printStackTrace();
System.out.println("关闭目标文件失败!");
}
try{
if(fr!=null) fr.close();
}catch(IOException e){
e.printStackTrace();
System.out.println("关闭源文件失败!");
}
}
}