BufferReader 与 BufferWriter的相关用法
众所周知,在实际应用中操作文件是很常见的。但由于不同电脑的文本格式有差异,会造成代码的移植性会比较差。Java中操作文件的库函数是比较丰富的,此处推荐一个自己平时常用的两个文件类。
1. 定义
BufferedReader br = new BufferedReader(new InputStreamReader(
new FileInputStream("filePathName")));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(
new FileOutputStream("filePathName")));
2. 使用示例
示例是将一个类似csv(每一行的元素用,隔开的一种文件格式)格式的文本文件处理变成Json格式的文件(后期要稍微处理一下,此处格式不规范)。
- 代码的精髓在8-12行,InputStreamReader和OutputStreamWriter的第二个参数可以指定编码格式,也就是说你可以以想要的格式读写文件(Java 的Eclipse默认是采用本机默认的格式打开,可能会出现错误。例如你直接去访问一个utf-8格式的文件,可能会出现乱码)。
- 代码16行,通过BufferReader,可以以一行读取文本内容,增加了代码处理的简洁性。
- 代码20-21行,通过BufferedWriter的write()和newLine()函数,以行的形式将内容写进文件。
代码
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class GetEdge {
public static void main(String[] args) throws IOException{
// TODO Auto-generated method stub
String path2 = "C:\\Users\\Administrator\\Desktop\\getAll_num.txt";
String path1 = "C:\\Users\\Administrator\\Desktop\\getNum.txt";
BufferedReader br = new BufferedReader(new InputStreamReader(
new FileInputStream(path2)));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(
new FileOutputStream(path1),"utf-8"));
String line=null;
String result[]=null;
String edge=null;
int count=0;
while ((line = br.readLine()) != null) {
System.out.println(line);
result=line.split(",");
edge="{\n\t\"id\":"+count+",\n\t\"source\":"+result[1]+",\n\t\"target\":"+result[0]+
",\n\t\"num\":"+result[2]+"\n },";
bw.write(edge);
bw.flush();
bw.newLine();
count++;
}
}
}
getAll_num.txt文件部分内容
138,1,1
141,1,1
3,2,1
4,2,1
74,2,1
76,2,1
4,3,1
38,3,1
40,3,2
143,3,1
146,3,1
3,4,4
40,4,3
108,4,1
183,4,1
40,5,1
180,5,1
40,6,1
43,6,1
75,6,1
getNum.json文件部分内容
{
"id":0,
"source":1,
"target":138,
"num":1
},
{
"id":1,
"source":1,
"target":141,
"num":1
},
{
"id":2,
"source":2,
"target":3,
"num":1
},
{
"id":3,
"source":2,
"target":4,
"num":1
},
{
"id":4,
"source":2,
"target":74,
"num":1
},
{
"id":5,
"source":2,
"target":76,
"num":1
},