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
Ответы
Ответ 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 классе