Работя върху импортирането на данни от Excel файл в Java JTable
. Мога да импортирам целия лист, но искам да импортирам само някои редове. Това е кодът, който използвам за импортиране на листа:
private void remplirtable(JTable table, int numfeuil,String s) {
Workbook wb;
File fichier = new File(s);
try {
//création de la table et importation du fichier
wb = Workbook.getWorkbook(fichier);
Sheet sheet = wb.getSheet(numfeuil);
String[] columnsnames=new String[sheet.getColumns()];
DefaultTableModel model = new DefaultTableModel();
//Remplir la table désignée
table.setModel(model);
int colonnes = sheet.getColumns();
int lignes = sheet.getRows();
Object data[] = new Object[colonnes];
for (int i=0; i<lignes; i++){
for (int j=0; j<colonnes; j++){
if (i==0)
{
//Component c=super.prepareRenderer(renderer, j, i);
model.addColumn(sheet.getCell(j,i).getContents());
}
//System.out.println(sheet.getCell(j,i).getContents());
if(i>=1)
data[j]=sheet.getCell(j,i).getContents();
}model.addRow(data);
}model.removeRow(0);
} catch (BiffException | IOException e) {
}
}
За да импортирам само редовете (3,4,5), използвах този код. A
е масивът, в който съхраняваме номерата на редовете:
private void RemplirPostes(JTable table, int numfeuil,String s,int[] A) {
Workbook wb;
File fichier = new File(s);
try {
//création de la table et importation du fichier
wb = Workbook.getWorkbook(fichier);
Sheet sheet = wb.getSheet(numfeuil);
DefaultTableModel model = new DefaultTableModel();
//Remplir la table désignée
table.setModel(model);
int colonnes = sheet.getColumns();
Object data[] = new Object[colonnes];
for(int k=0;k<A.length;k++)
{
for (int j=0; j<colonnes; j++){
if (A[k]==0)
{
//Component c=super.prepareRenderer(renderer, j, i);
model.addColumn(sheet.getCell(j,A[k]).getContents());
}
//System.out.println(sheet.getCell(j,i).getContents());
if(A[k]>=1)
data[j]=sheet.getCell(j,A[k]).getContents();
}model.addRow(data);
}
model.removeRow(0);
} catch (BiffException | IOException e) {
}
}
И всичко това не работи.
And all this doesn't work.
Можете ли да уточните? Какво ще кажеш, че не работи? Компилира ли се? да се държа лошо? Изключения (не бих препоръчал да ги поглъщате - поне направете нещо, като отпечатайте проследяването на стека:catch (BiffException | IOException e) {e.printStackTrace();}
)? - person copeg   schedule 05.05.2015