我有一个45311实例的输入文件。在应用我的编程任务之后。当我把它写回新文件时,它实际上只写了43371实例。它运行成功,但我剩下的实例在哪里。
package kmean;
//package greenblocks.statistics;
import java.io.IOException;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import weka.clusterers.SimpleKMeans;
import weka.core.Instances;
/**
*
* @author admin
*/
public class Kmean {
public static BufferedReader readDataFile(String filename) {
BufferedReader inputReader = null;
try {
inputReader = new BufferedReader(new FileReader(filename));
} catch (FileNotFoundException ex) {
System.err.println("File not found: " + filename);
}
return inputReader;
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) throws IOException, Exception {
BufferedWriter writer = null;
try {
writer = new BufferedWriter(new FileWriter("perturbed1.csv"));
}
catch (IOException e) {
}
SimpleKMeans kmeans = new SimpleKMeans();
kmeans.setSeed(10);
//important parameter to set: preserver order, number of cluster.
kmeans.setPreserveInstancesOrder(true);
kmeans.setNumClusters(5);
BufferedReader datafile = readDataFile("elecNormNew.arff");
// BufferedReader datafile = readDataFile("perturbed.csv");
Instances data = new Instances(datafile);
kmeans.buildClusterer(data);
// This array returns the cluster number (starting with 0) for each instance
// The array has as many elements as the number of instances
int[] assignments = kmeans.getAssignments();
StringBuilder sb = new StringBuilder();
int i=0;
for(int clusterNum : assignments) {
// System.out.printf("Instance %d -> Cluster %d \n", i, clusterNum);
sb.append(i);
sb.append(";");
sb.append(clusterNum);
sb.append("\n");
//System.out.printf("\n");
i++;
}
System.out.println(sb.toString());
writer.write(sb.toString()+"\n");
// TODO code application logic here
}
}
答案 0 :(得分:2)
在写完所有数据后,您应该在结束时调用writer.close()
。
答案 1 :(得分:2)
关于缓冲文件编写器的简洁事实是,它们接受您的输入并保留它,直到缓冲区已满。这减少了i / o操作。最多只有一个写操作适合一个hdd写缓冲区,因此操作系统将整个缓冲区作为一个i / o命令。缺点是如果最后如果没有flush()
缓冲区,则其余内容将不会写入磁盘。如果您调用close()
,将写入任何挂起的字节并释放资源。在java 7及更高版本中,您可以通过在try
语句中打开流来使用自动关闭功能:
try(Inputstream is = new ...) {
如果您的代码后面可能有任何数据要写,您可以使用.flush()
来确保写入数据。
默认情况下,缓冲区大小设置为8k,但这可能会违反jre和version。
答案 2 :(得分:0)
而不是writer.write(sb.toString()+"\n");
尝试writer.write(sb.toString()+writer.newLine());
用
完成写作进度writer.flush();
writer.close();
我自己遇到了一些问题" \ n" maby认为这个问题。