Java读取文件涉及的换行符问题
首先需要把数据库中的多列导出成txt文本,然后java代码读取该文件,通过readline读取每一行,再通过"\t" 分割spit每一列数据,分别对其进行处理。
结果读取每一行的时候发现本来在一行的数据分成了两行,查找原因发现,原来是数据库列中的数据本身已存在换行符,这就需要在导出数据的时候对该列进行一个去除换行符的操作。
REPLACE(title, "\r\n", "")
解决办法如下:
java \r\n 或者 \n
mysql,javascript \r\n
windows下的文本换行符是 \r\n
unix下的文本换行符是 \n
try{
BufferedReader in = new BufferedReader(new FileReader(fileName));
balance=in.readLine();
while(in.read()!=-1){ //注
content.append(in.readLine()+'\n');
}
注:
这里的in.read()每次都会读入一个字符,从而使文件指针向后一位,你试着把这个循环换成
while((st=in.readLine())!=null) //这里st在前定义为String
{
content.addend(st+"\n")
}
再试试行不
这里错了:
BufferedReader in = new BufferedReader(new FileReader(fileName));
balance=in.readLine();
while(in.read()!=-1){
content.append(in.readLine()+'\n');
}
in.close();
}
这样写吧:
String inputLine;
while ((inputLine = in.readLine()) != null) {
content.append(inputLine+"\n");
}
原因;
while(in.read()!=-1)
这里会读一个字符进来,然后指针会后移一个字符,所以出现你的现象。
注意,每次读取Buffer里面的东西都会导致指针后移。
BufferedReader in = new BufferedReader(new FileReader(fileName));
而:FileWriter(File file)中的参数是File的,而你的filename只是个String,应该先把它弄成一个实例,再传递过去:
File file = new File(fileName);
BufferedReader in = new BufferedReader(new FileReader(file));
.....
while((balance=in.readLine())!=null){
content=new StringBuffer(balance);//之前的content是这样声明的:StringBuffer content = null;
content.append(inputLine+"\n");
}
...
f2=Float.parseFloat(balance);//这里有问题,但不怎么懂你的意思 你自己改 我运行的时候把它注释掉了的 嘿嘿
...
if(content!=null)
out.write(new String(content));
...
基本上没改什么了 估计不是你想要的结果(-_-)
拿2分闪人...