读取txt文件中的信息,每次读取一行,解析其中的数据,涉及到字符串切分,使用的 ^ 切分,在使用split的时候需要用\\转译
问题:本机和远程服务器解析字符串,同样的代码,切分后的字符串长度不一致。
解决后代码
public class Test {
public static void main(String[] args) throws IOException {
File f=new File("C:\\Users\\***\\Desktop\\555.txt");
String line="";
int count=1;
BufferedReader br=new BufferedReader(new InputStreamReader(new FileInputStream(f),"utf-8"));
while (true){
line= br.readLine();
if (line==null){
break;
}
String[] split = line.split("\\^");
System.out.println(count+"--"+split.length);
count++;
}
}
}
最后抱着试一试的态度,添加了编码级 utf-8 ,发现解决了本机和远程服务器A解析字符串结果不一致的问题,中间还出现同样的代码,本机下载另一个远程服务器B的文件没有乱码出现,而远程服务器A下载后的代码乱码,因为原来是使用字符流下载,所以改为了字节流下载,解决了乱码问题,相信如果添加编码级,使用字符流也能解决问题。