怎么用java将sql查询结果存成weka的标准.arff文件?

已经用publicvoidquestQuery(){try{Stringsql="select*fromtest1";ResultSetrs=DataPrep.getRS... 已经用
public void questQuery(){
try{
String sql ="select * from test1";
ResultSet rs = DataPrep.getRS(sql);
while (rs.next()){
System.out.println(rs.getInt("morning_cmt")+" "+rs.getInt("night_sts"));
}
} catch (Exception e){
e.printStackTrace();
}
}
查到了所需要的数据 怎么存成.arff文件呢?

instance那块不是很明白
展开
 我来答
lisinan0727
推荐于2016-07-27 · TA获得超过618个赞
知道小有建树答主
回答量:213
采纳率:0%
帮助的人:238万
展开全部
weka的arff格式
@relation ‘ 这里填写一些对实例的处理记录,没啥特别用处’
@attribute 属性名称 属性类别 这里你就要把数据库中的表中的键及对应类型写入
@data
{属性编号 属性值,属性编号 属性值 。。。} 数据库中的第一条数据
{属性编号 属性值,属性编号 属性值 。。。} 数据库中的第二条数据
{属性编号 属性值,属性编号 属性值 。。。}
{属性编号 属性值,属性编号 属性值 。。。}

知道了这个格式,你就可以直接按照改格式用buffer写出去保存为arff格式即可
更多追问追答
追问
没错 比如我需要保存2个attribute morning_cmt 和night_sts, 用sql查出来以后,怎么写到arff文件里呢?打印出来我明白是
while (rs.next()){
System.out.println(rs.getInt("morning_cmt")+" "+rs.getInt("night_sts"));
}
要是存进文件呢?addElement()还是什么么?
追答

import weka.core.Instances;

import weka.experiment.InstanceQuery;

...

InstanceQuery query = new InstanceQuery();

query.setDatabaseURL("jdbc_url");

query.setUsername("the_user");

query.setPassword("the_password");

query.setQuery("select * from whatsoever");

// if your data is sparse, then you can say so, too:

// query.setSparseData(true);

Instances data = query.retrieveInstances();

或者

import weka.core.Instances;

import weka.core.converters.DatabaseLoader;

...

DatabaseLoader loader = new DatabaseLoader();

loader.setSource("jdbc_url", "the_user", "the_password");

loader.setQuery("select * from whatsoever");

Instances data = loader.getDataSet();

 

增量式:

import weka.core.Instance;

import weka.core.Instances;

import weka.core.converters.DatabaseLoader;

...

DatabaseLoader loader = new DatabaseLoader();

loader.setSource("jdbc_url", "the_user", "the_password");

loader.setQuery("select * from whatsoever");

Instances structure = loader.getStructure();

Instances data = new Instances(structure);

Instance inst;

while ((inst = loader.getNextInstance(structure)) != null)

data.add(inst);

注意

• Not all database systems allow incremental retrieval.

• Not all queries have a unique key to retrieve rows incrementally. In that

case, one can supply the necessary columns with thesetKeys(String)

method (comma-separated list of columns).

• If the data cannot be retrieved in an incremental fashion, it is first fully

loaded into memory and then provided row-by-row (“pseudo-incremental”).

匿名用户
2013-04-21
展开全部
以前接触过weka,有些忘,刚翻了下,假如你要把Instances的一个对象data存入到D://test.arff文件中。
ArffSaver saver = new ArffSaver();//ArffSaver 类是写入arff文件的相关类
saver.setInstances(data);//设置你要存的instances
saver.setFile(new File("D://test.arff"));//设置目标文件
saver.writeBatch();//把instance们写入
追问

请问遇到如下状况该怎么办?DatabaseUtils.props已经修改过了

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式