prefuse学习(一)用非数据库连接和xml的方式读入数据
生活随笔
收集整理的這篇文章主要介紹了
prefuse学习(一)用非数据库连接和xml的方式读入数据
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
prefuse正常的數據源需要從ConnectionFactory中生產出來,但是如果平時不想用里面給的方法得到數據,就需要手動創造Graph里面所需要的內容兩個Table
下面是我自己寫的從文件中讀入數據的工具類
package wjl.util;import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.util.Scanner;import prefuse.data.Table;public class PreTable {public static Table filemake(String path){FileInputStream in = null;Scanner cin = null;Table nodes = new Table();try {in = new FileInputStream(path);cin = new Scanner(in);String fieldname[] = cin.nextLine().split("\t");for(String name:fieldname){if(!name.contains("id"))nodes.addColumn(name, String.class);elsenodes.addColumn(name, int.class);}while(cin.hasNext()){int row = nodes.addRow();String data[] = cin.nextLine().split("\t");for(int i=0;i<fieldname.length;i++){if(fieldname[i].contains("id"))nodes.setInt(row, i, Integer.parseInt(data[i]));elsenodes.set(row, i, data[i]);}}} catch (FileNotFoundException e) {e.printStackTrace();}finally{if(null != in){try {in.close();} catch (IOException e) {e.printStackTrace();}}if(null != cin){cin.close();}}return nodes;} }上面的需要注意幾點1.由于之后創建圖的時候需要指定從edges的哪個指向哪個,所以要求nodes中的被指定的主建只能是int,edges中兩個頂點u,v也只能是int,所以我在我的算法里規定如果一個域的名字中存在id則類型設置成int,否則統一變成String。
轉載于:https://www.cnblogs.com/MengYan-LongYou/p/3163592.html
總結
以上是生活随笔為你收集整理的prefuse学习(一)用非数据库连接和xml的方式读入数据的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hive处理日志,自定义inputfor
- 下一篇: sql数据库恢复