prefuse学习(一)用非数据库连接和xml的方式读入数据
生活随笔
收集整理的這篇文章主要介紹了
prefuse学习(一)用非数据库连接和xml的方式读入数据
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
prefuse正常的數(shù)據(jù)源需要從ConnectionFactory中生產(chǎn)出來(lái),但是如果平時(shí)不想用里面給的方法得到數(shù)據(jù),就需要手動(dòng)創(chuàng)造Graph里面所需要的內(nèi)容兩個(gè)Table
下面是我自己寫(xiě)的從文件中讀入數(shù)據(jù)的工具類
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;} }上面的需要注意幾點(diǎn)1.由于之后創(chuàng)建圖的時(shí)候需要指定從edges的哪個(gè)指向哪個(gè),所以要求nodes中的被指定的主建只能是int,edges中兩個(gè)頂點(diǎn)u,v也只能是int,所以我在我的算法里規(guī)定如果一個(gè)域的名字中存在id則類型設(shè)置成int,否則統(tǒng)一變成String。
轉(zhuǎn)載于:https://www.cnblogs.com/MengYan-LongYou/p/3163592.html
總結(jié)
以上是生活随笔為你收集整理的prefuse学习(一)用非数据库连接和xml的方式读入数据的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: hive处理日志,自定义inputfor
- 下一篇: sql数据库恢复