Подтвердить что ты не робот

EDITED Запись JTable в Excel

Я пытаюсь экспортировать файл JTable в Excel. Имена столбцов и строк хороши, но вся информация, которую я добавляю в JTable, не записывается. Я попробовал System.out.println() и печатает значения Null везде, кроме имен столбцов и строк. Я попытался получить ответы от мамы google, но после 2 часов чтения и попытки, до сих пор нет прогресса.  То, что остается в моей голове, заключается в том, что может быть некоторая ошибка в коде в разделе "Write to Excel" или все, что добавлено в JTable, это просто изображение на моем мониторе, а не фактические данные в нем.? Исправьте меня, если я ошибаюсь, и любая помощь очень ценится.

Вот запись в Excel. в первом цикле For я получаю заголовки и во втором цикле For, я должен получить все, что находится внутри моего JTable, но я не знаю.

TableColumnModel tcm = nrp.rotaTable.getColumnModel();

    String nameOfFile = JOptionPane.showInputDialog("Name of the file");

    Workbook wb = new HSSFWorkbook();
    CreationHelper createhelper = wb.getCreationHelper();

    Sheet sheet = wb.createSheet("new sheet");
    Row row = null;
    Cell cell = null;

    for (int i = 0; i < nrp.tableModel.getRowCount(); i++) {
        row = sheet.createRow(i);
        for (int j = 0; j < tcm.getColumnCount(); j++) {

            cell = row.createCell(j);
            cell.setCellValue(tcm.getColumn(j).getHeaderValue().toString());

        }
    }
    for (int i = 1; i < nrp.tableModel.getRowCount(); i++) {
        row = sheet.createRow(i);
        System.out.println("");
        for (int j = 0; j < nrp.tableModel.getColumnCount(); j++) {

            cell = row.createCell(j);
            cell.setCellValue((String) nrp.tableModel.getValueAt(i, j)+" ");
            System.out.print((String) nrp.tableModel.getValueAt(i, j)+" ");
        }
    }


    File file = new File("Some name.xls");
    FileOutputStream out = new FileOutputStream(file);
    wb.write(out);
    out.close();
    wb.close();
  }
}

И вот код FocusListener.

rotaTable.addFocusListener(new FocusListener() {
            public void focusGained(FocusEvent e) {
            }
            public void focusLost(FocusEvent e) {
                CellEditor cellEditor = rotaTable.getCellEditor();
                if (cellEditor != null)
                    if (cellEditor.getCellEditorValue() != null)
                        cellEditor.stopCellEditing();
                    else
                        cellEditor.cancelCellEditing();
            }
        });

Я использую 'DefaultTableModel'

 DefaultTableModel tableModel = new DefaultTableModel(12,8); 
JTable rotaTable = new JTable(tableModel); 

Это первый раз, когда я работаю с библиотекой POI.

Изображение моего JTable http://imgur.com/a/jnB8j

Изображение распечатанных результатов в консоли http://imgur.com/a/jnB8j

Создано изображение файла Excel. http://imgur.com/a/jnB8j

4b9b3361

Ответ 1

Вам нужно начинать индекс строки на 0, потому что строка таблицы начинается с 0 и создает строку excel из 1, потому что сначала вы записываете имена столбцов. Я изменил ваш второй цикл:

for (int i= 0; i < nrp.tableModel.getRowCount(); i++) {
    row = sheet.createRow(i+1);
    System.out.println("");
    for (int j = 0; j < nrp.tableModel.getColumnCount(); j++) {
        cell = row.createCell(j);
        if(nrp.tableModel.getValueAt(i, j)!=null){
        cell.setCellValue((String) nrp.tableModel.getValueAt(i, j));
        }
        System.out.print((String) nrp.tableModel.getValueAt(i, j)+" ");
    }
}

Ответ 2

Как только я написал этот код, он используется для записи набора JTables в файл Excel (один рядом с другим). Как я вижу, это тот же самый код, который вы написали. Не могли бы вы попробовать это, а не блокировать. Вы должны заменить объект Entry или обернуть таблицу в Map

for (int i = 1; i < nrp.tableModel.getRowCount(); i++) {
...
}

Поскольку мне нужно было писать таблицы один рядом с другим, я использовал переменную fila и columna, чтобы получить текущую позицию для размещения следующей таблицы. Вы можете установить их в 0 или 1 для проведения тестов. Возможно, это может помочь вам придумать новые идеи.

Также единственная разница, которую я замечаю:   if (row == null) {...}

private void escribirContenido(Sheet hoja, Entry<String, JTable> e) {
    Row row;
    Cell cell;
    for (int i = fila; i < e.getValue().getRowCount() + fila; i++) {
        row = hoja.getRow(i);
        if (row == null) {
            row = hoja.createRow(i);
        }
        for (int j = 0; j < e.getValue().getColumnCount(); j++) {
            cell = row.createCell(j + columna);
            String value = String.valueOf(e.getValue().getValueAt(i - fila, j));
            try {
                cell.setCellValue(new Double(value));
            } catch (NumberFormatException e1) {
                cell.setCellValue(value);
            }
        }
    }
}

Ответ 3

import java.awt.Color;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Vector;

import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.ListSelectionModel;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CreationHelper;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;

@SuppressWarnings("serial")
public class EmployeePanel extends JPanel {
    public ArrayList columnNames = new ArrayList();
    ArrayList data = new ArrayList();
    Connection conn;
    String query;
    String sql = "SELECT * FROM employee";
    String url = "jdbc:mysql://localhost:3306/nandos_db";
    String userid = "User1";
    String password = "Password1";
    Statement stmt;
    ResultSet rs;
    int rows = 0;
    int columns = 0;
    JTable employeeTable;

    @SuppressWarnings({ "unchecked" })
    public EmployeePanel() {
        super();
        this.setBackground(Color.GREEN);
        this.setLayout(null);
        this.setVisible(true);
        try {
            conn = DriverManager.getConnection(url, userid, password);
            stmt = (Statement) conn.createStatement();
            rs = stmt.executeQuery(sql);
            ResultSetMetaData md = (ResultSetMetaData) rs.getMetaData();

            int columns = md.getColumnCount();
            for (int i = 1; i <= 3; i++) {
                columnNames.add(md.getColumnName(i));
            }
            while (rs.next()) {
                ArrayList row = new ArrayList(columns);
                for (int i = 1; i <= columns; i++) {
                    row.add(rs.getObject(i));
                }
                data.add(row);
            }
            // Get row data
        } catch (SQLException e) {
            // System.out.println(e.getMessage());
            e.printStackTrace();
        }
        // Create Vectors and copy over elements from ArrayLists to them
        // a custom defined class which inherits from the AbstractTableModel
        // class
        Vector columnNamesVector = new Vector();
        Vector dataVector = new Vector();
        for (int i = 0; i < data.size(); i++) {
            ArrayList subArray = (ArrayList) data.get(i);
            Vector subVector = new Vector();
            for (int j = 0; j < subArray.size(); j++) {
                subVector.add(subArray.get(j));
            }
            dataVector.add(subVector);
        }
        for (int i = 0; i < columnNames.size(); i++) {
            columnNamesVector.add(columnNames.get(i));
        }
        // Create table with database data
        employeeTable = new JTable(dataVector, columnNamesVector);
        employeeTable.getTableHeader().setOpaque(false);
        employeeTable.getTableHeader().setBackground(Color.pink);
        employeeTable.setBackground(Color.orange);
        employeeTable.setSelectionMode((ListSelectionModel.SINGLE_SELECTION));
        employeeTable.setEnabled(true);
        employeeTable.setDragEnabled(false);
        employeeTable.setCellEditor(null);

        JScrollPane sp = new JScrollPane(employeeTable);
        sp.setSize(1030, 540);
        sp.setLocation(10, 10);
        this.add(sp);
    }

    public static void main(String... args) throws IOException {
        JFrame f = new JFrame();
        EmployeePanel t = new EmployeePanel();
        f.add(t);
        f.setVisible(true);
        f.pack();

        System.out.println(t.employeeTable.getValueAt(0, 0));

        Workbook wb = new HSSFWorkbook();
        CreationHelper createhelper = wb.getCreationHelper();

        Sheet sheet = wb.createSheet("new sheet");
        Row row = null;
        Cell cell = null;
        row = sheet.createRow(0);
        for (int i = 0; i < t.employeeTable.getColumnCount(); i++) {
            cell = row.createCell(i);
            cell.setCellValue(String.valueOf(t.employeeTable.getColumnName(i)));
        }

        for (int j = 1; j <= t.employeeTable.getRowCount(); j++) {
            row = sheet.createRow(j);
            for (int i = 0; i < t.employeeTable.getColumnCount(); i++) {
                cell = row.createCell(i);

                cell.setCellValue(String.valueOf(t.employeeTable.getValueAt(j - 1, i)));

            }
        }

        File file = new File("C:\\Users\\test\\Desktop\\Some name.xls");
        FileOutputStream out = new FileOutputStream(file);
        wb.write(out);
        out.close();
        wb.close();

    }

}

если я позволю этому коду подключиться к моей базе данных, плохо получим лист excel с тем же содержимым, что и таблица в кадре. поскольку у вас, очевидно, есть еще какой-то код, который вы еще не показывали, вам, возможно, потребуется его правильно адаптировать. этот код работает всего в 1 классе