Я хочу сохранить результаты чтения lucene индекс в jTable, так, чтобы я мог сделать это поддающимся сортировке различными столбцами. От индекса я читаю условия с различными мерами их частот.
Столбцы таблицы - они: [строковый термин] [интервал absFrequency] [интервал docFrequency] [удваивает invFrequency]
Так я в AbstractTableModel я могу определить имена столбцов, но я не знаю, как получить Объект [] [] данные с результатами следующего метода:
public static void FrequencyMap(Directory indexDir) throws Exception
{
List<ArrayList>redoviLista = new ArrayList<ArrayList>();
//final Map<String,TermRow> map = new TreeMap<String,TermRow>();
List<String>termList = new ArrayList<String>();
IndexReader iReader = IndexReader.open(indexDir);
FilterIndexReader fReader = new FilterIndexReader(iReader);
int numOfDocs = fReader.numDocs();
TermEnum terms = fReader.terms();
while (terms.next()){
Term term = terms.term();
String termText = term.text();
termList.add(termText);
//Calculating the frequencies
int df = iReader.docFreq(term);
double idf = 0.0F;
idf = Math.log10((double) numOfDocs / df);
double tfidf = (df*idf);
//Here comes important part
//Changes according to takoi's answer
ArrayList<Object> oneRow = new ArrayList<Object>();
oneRow.add(termText);
oneRow.add(df);
oneRow.add(idf);
oneRow.add(tfidf);
redoviLista.add(oneRow);
}
iReader.close();
// So I need something like this, and i Neeed this array to be stored out of this method
Таким образом, я - kindda, застрявший здесь, чтобы продолжить реализовывать AbstractTableModel и заполнять и отображать эту таблицу....:/
Помогите!
Когда вы вставляете, удаляете или обновляете данные в вашей модели, вам необходимо уведомить GUI об изменениях. Вы можете сделать это с помощью fire-методов в AbstractTableModel
.
Например, если вы добавляете элемент в список, вам также нужно вызвать fireTableRowsInserted(int firstRow, int lastRow)
, чтобы обновить видимый слой.
Посмотрите на addElement(MyElement e)
в коде ниже:
public class MyModel extends AbstractTableModel {
private static final String[] columnNames = {"column 1", "column 2"};
private final LinkedList<MyElement> list;
private MyModel() {
list = new LinkedList<MyElement>();
}
public void addElement(MyElement e) {
// Adds the element in the last position in the list
list.add(e);
fireTableRowsInserted(list.size()-1, list.size()-1);
}
@Override
public int getColumnCount() {
return columnNames.length;
}
@Override
public int getRowCount() {
return list.size();
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
switch(columnIndex) {
case 0: return list.get(rowIndex).getColumnOne();
case 1: return list.get(rowIndex).getColumnOne();
}
return null;
}
}
Вам не нужно создавать объект [] []. Просто сделайте свой redoviLista списком списков:
redoviLista.add( new ArrayList<Object>(termText, df, idf, tfidf) ); #pseudocode
затем вы реализуете getValueAt следующим образом:
getValueAt(int row, int column){
redoviLista.get(row).get(column);
}
Для этого нет необходимости создавать настраиваемую модель таблицы. Просто используйте DefaultListModel.
DefaultListModel позволяет динамически добавлять строки в модель с помощью метода addRow (...) и автоматически вызывает соответствующий метод fireXXX, чтобы таблица перерисовывалась.
Базовый код будет выглядеть так:
DefaultTableModel model = new DefaultTableModel( columnNames );
while (...)
{
Vector row = new Vector();
row.add(...)
row.add(...)
model.addRow( row );
}
JTable table = new JTable( model );
Вам не нужно каждый раз создавать собственную модель таблицы. Иногда можно начать с DefaultTableModel.