Прочитайте Excel и покажите его в виде таблицы. Заполните TableView, используя 2D массив или список списка - PullRequest
0 голосов
/ 05 июня 2019

Моя цель - прочитать Excel (что я могу, через Apache POI) и отобразить Excel в TableView (JavaFX).Я могу отображать имена столбцов на TableView, но не могу заполнить данные в этих столбцах

Для многих доступных ресурсов я нашел общий пример, где создается отдельный класс (в котором переменные инициализируются,геттеры и сеттеры пишутся) и через конструктор значения передаются в TableView.Но в моем случае я не могу жестко закодировать эти переменные.Я пытаюсь заполнить TableView, когда неизвестно количество столбцов, которое будет иметь TableView.Вот что я пробовал до сих пор.

package sample;

import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.scene.control.TableColumn;
import javafx.stage.FileChooser;
import javafx.stage.Stage;
import javafx.scene.control.TableView;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;

public class Controller {

    @FXML public TableView tableView;

    public void quitMethod(ActionEvent actionEvent) {
        System.out.println("quit button was pressed");
        System.exit(0);
    }

    public void browseMethod(ActionEvent actionEvent) throws IOException {
        Stage stage = new Stage();

        FileChooser fileChooser = new FileChooser();
        fileChooser.setTitle("Select File");
        fileChooser.setInitialDirectory(new File("C:/"));
        fileChooser.getExtensionFilters().addAll(
                new FileChooser.ExtensionFilter("xls files", "*.xls"),
                new FileChooser.ExtensionFilter("xlsx files", "*.xlsx")
        );
        File file = fileChooser.showOpenDialog(stage);
        String path = file.getPath();
        ArrayList<ArrayList> excel = ReadExcel.main1(path);

        for (int i=0; i<excel.get(0).size();i++) {
            TableColumn<Controller, String> firstcol = new TableColumn<>    (excel.get(0).get(i).toString());
            tableView.getColumns().add(firstcol);
            ObservableList<ArrayList<Controller>> data = FXCollections.observableArrayList(excel.get(i));
            tableView.setItems(data);
        }

    }

}

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

1 Ответ

0 голосов
/ 10 июня 2019

Я создал демо, которое объясняет, как заполнить TableView, когда число столбцов неизвестно.Комментарии в коде.

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javafx.application.Application;
import javafx.beans.property.ReadOnlyObjectWrapper;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
import org.apache.poi.EncryptedDocumentException;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;

/**
 *
 * @author blj0011
 */
public class JavaFXApplication124 extends Application
{
    @Override
    public void start(Stage primaryStage)
    {        
        ObservableList<ObservableList<String>> data = FXCollections.observableArrayList();        
        final List<List<String>> excelData = readExcelFile("fileName.xlsx");//Get data from excel file
        //Add excel data to an observable list
        for(int i = 0; i < excelData.size(); i++)
        {
            data.add(FXCollections.observableArrayList(excelData.get(i)));
        }

        TableView<ObservableList<String>> tableView = new TableView();
        tableView.setItems(data);

        //Create the table columns, set the cell value factory and add the column to the tableview.
        for (int i = 0; i < excelData.get(0).size(); i++) {
            final int curCol = i;
            final TableColumn<ObservableList<String>, String> column = new TableColumn<>(
                    "Col " + (curCol + 1)
            );
            column.setCellValueFactory(
                    param -> new ReadOnlyObjectWrapper<>(param.getValue().get(curCol))
            );
            tableView.getColumns().add(column);
        }

        VBox vbox = new VBox(tableView);

        Scene scene = new Scene(vbox);

        primaryStage.setScene(scene);

        primaryStage.show();

    }

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args)
    {
        launch(args);
    }

    public static List<List<String>> readExcelFile(String fileName)
    {
        List<List<String>> excelContent = new ArrayList();
        int columnCounter = 0;
        int rowCounter = 0;

        try (InputStream inputStream = new FileInputStream(fileName)) {
            DataFormatter formatter = new DataFormatter();

            Workbook workbook = WorkbookFactory.create(inputStream);
            Sheet sheet = workbook.getSheetAt(0);

            for (Row row : sheet) {
                List<String> tempList = new ArrayList();

                for (Cell cell : row) {
                    String text = formatter.formatCellValue(cell);
                    System.out.print(++columnCounter + ": " + text + " - ");
                    System.out.println(text.length());
                    tempList.add(text.length() == 0 ? "" : text);
                }
                columnCounter = 0;
                excelContent.add(tempList);

                ++rowCounter;
                if (rowCounter == 5) {
                    break;
                }
            }
        }
        catch (IOException | EncryptedDocumentException ex) {
            System.out.println(ex.toString());
        }

        return excelContent;
    }
}

Я собираюсь выйти на конечность и отдать этот ответ @jewelsea.https://coderanch.com/t/663384/java/Populating-TableView-method

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...