A continuación tenemos una clase que nos permite arrastrar un archivo de Excel (*.xlsx) y cargar su contenido en una tabla de java. Esta realizado con Java 8 y el IDE Netbeans. Ademas son necesarios algunas librerías extras, las cuales son:
Código clase DropXlsx
import java.awt.HeadlessException; import java.awt.datatransfer.DataFlavor; import java.awt.datatransfer.Transferable; import java.awt.datatransfer.UnsupportedFlavorException; import java.awt.dnd.DnDConstants; import java.awt.dnd.DropTarget; import java.awt.dnd.DropTargetDragEvent; import java.awt.dnd.DropTargetDropEvent; import java.awt.dnd.DropTargetEvent; import java.awt.dnd.DropTargetListener; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.Iterator; import javax.swing.JOptionPane; import javax.swing.JTable; import javax.swing.table.DefaultTableModel; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.xssf.usermodel.XSSFSheet; import org.apache.poi.xssf.usermodel.XSSFWorkbook; /** * @see https://www.jc-mouse.net/ * @author mouse */ public class DropXlsx implements DropTargetListener { private JTable jtable; private DefaultTableModel tableModel; protected DropTarget dropTarget; /** * Constructor de clase */ public DropXlsx() { } public void setJtable(JTable jtable) { this.jtable = jtable; dropTarget = new DropTarget(jtable, this); tableModel = new DefaultTableModel(); } @Override public void dragEnter(DropTargetDragEvent dtde) {/*...*/ } @Override public void dragOver(DropTargetDragEvent dtde) {/*...*/ } @Override public void dropActionChanged(DropTargetDragEvent dtde) {/*...*/ } @Override public void dragExit(DropTargetEvent dte) {/*...*/ } @Override public void drop(DropTargetDropEvent dtde) { try { /* proporciona datos para operaciones de transferencia en swing */ Transferable tr = dtde.getTransferable(); /* Devuelve una array de objetos DataFlavor */ DataFlavor[] flavors = tr.getTransferDataFlavors(); if (flavors.length > 0) { /* Si existe una lista de objetos de archivo */ if (flavors[0].isFlavorJavaFileListType()) { dtde.acceptDrop(DnDConstants.ACTION_COPY); /* obtiene un List con los archivos arrastrados al componente */ java.util.List list = (java.util.List) tr.getTransferData(flavors[0]); if (!list.isEmpty()) { /* abre el primer archivo */ File file = new File(list.get(0).toString()); if (file.exists()) { /* Si el archivo corresponde a un archivo excel *.xlsx */ if (file.getName().endsWith("xlsx")) { readXLSX(file); } else { JOptionPane.showMessageDialog(null, "No es un archivo *.xlsx valido", "Error", JOptionPane.ERROR_MESSAGE); } } else { System.err.println("error archivo no existe "); } } dtde.dropComplete(true); return; } } dtde.rejectDrop(); } catch (UnsupportedFlavorException | IOException | HeadlessException ex) { System.err.println(ex.getMessage()); dtde.rejectDrop(); } } /** * Lee un archivo excel (Primera hoja) * * @param file Archivo excel */ private void readXLSX(File file) { tableModel = new DefaultTableModel(); try { XSSFWorkbook wb = new XSSFWorkbook(new FileInputStream(file)); XSSFSheet sheet = wb.getSheetAt(0);//primeta hoja Row row; Cell cell; //obtiene cantidad total de columnas con contenido int maxCol = 0; for (int a = 0; a <= sheet.getLastRowNum(); a++) { if(sheet.getRow(a)!=null){ if (sheet.getRow(a).getLastCellNum() > maxCol) { maxCol = sheet.getRow(a).getLastCellNum(); } } } if (maxCol > 0) { //Añade encabezado a la tabla for (int i = 1; i <= maxCol; i++) { tableModel.addColumn("Col." + i); } //recorre fila por fila Iterator<Row> rowIterator = sheet.iterator(); while (rowIterator.hasNext()) { int index = 0; row = rowIterator.next(); Object[] obj = new Object[row.getLastCellNum()]; Iterator<Cell> cellIterator = row.cellIterator(); while (cellIterator.hasNext()) { cell = cellIterator.next(); //contenido para celdas vacias while (index < cell.getColumnIndex()) { obj[index] = ""; index += 1; } //extrae contenido de archivo excel switch (cell.getCellType()) { case Cell.CELL_TYPE_BOOLEAN: obj[index] = cell.getBooleanCellValue(); break; case Cell.CELL_TYPE_NUMERIC: obj[index] = cell.getNumericCellValue(); break; case Cell.CELL_TYPE_STRING: obj[index] = cell.getStringCellValue(); break; case Cell.CELL_TYPE_BLANK: obj[index] = " "; break; case Cell.CELL_TYPE_FORMULA: obj[index] = cell.getCellFormula(); break; default: obj[index] = ""; break; } index += 1; } tableModel.addRow(obj); } jtable.setModel(tableModel); }else{ JOptionPane.showMessageDialog(null, "Nada que importar", "Error", JOptionPane.ERROR_MESSAGE); } } catch (IOException ex) { System.err.println("" + ex.getMessage()); } } }//DropXlsx:end
Y luego para usarlo en un JTable:
DropXlsx dropXlsx = new DropXlsx(); dropXlsx.setJtable(jTable1);
Dado una tabla excel con extensión *.xlsx arrastramos con el mouse a la aplicación
enjoy!!!
Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.
Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye
Enjoy! :)
La base de datos elegida es Access 2007 (*.accdb), pero claro la migracion hacia otra base de datos como MySQL o Postgre...
En ocasiones debemos insertar varios registros a nuestra base de datos desde nuestra aplicación java y lo que usualmente...
Cuando desarrollamos aplicaciones en el IDE (Entorno de Desarrollo Integrado) de Android Studio, es importante indicar e...
Yachaywasi versión 3.1 es una aplicación para android que te permite crear, editar y realizar exámenes tipo test cómodam...
Tiempo atras me pidieron un ejemplo de como realizar un reporte con iReport tipo factura, recibo o como le llamen, compl...
Hace tiempo me pidieron el código fuente de un juego de Puzzle de Neon Genesis Evangelión, este juego es completo, tiene...
Si trabajas con redes sociales (RRSS) a continuación te muestro tres herramintas gratuitas que te ayudaran a la hora de...
Por lo general se usan transacciones a nivel base de datos y posteriormente se llaman estos a través de procedimientos a...
En este post, aprenderemos como conectar Visual Basic 6 con SQL Server, abrir una tabla, leer su contenido y mostrar est...
Lo que veremos en este post es la configuración del driver para PHP de SQL Server que ha creado Microsoft el cual permit...