溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么將Java打開CSV文件到JTable展示

發(fā)布時(shí)間:2023-03-31 14:31:07 來(lái)源:億速云 閱讀:127 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“怎么將Java打開CSV文件到JTable展示”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“怎么將Java打開CSV文件到JTable展示”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

概述

主要知識(shí)點(diǎn)

a.SwingNode類 :把Java swing組件封裝成一個(gè)JavaFX的Node,使得Java Swing可以和JavaFX嵌套在一起使用,JavaSwing賊丑,但操作簡(jiǎn)單,JavaFX的表格組件(TableView等)有點(diǎn)復(fù)雜,所以選擇嵌套JavaSwing來(lái)使用,丑就丑吧

b.javacsv-2.0.jar: 用于通過(guò)文件地址讀取csv文件,并可以進(jìn)行一系列操作.盡管2008年之后就不再更新,但操作個(gè)csv文件也夠用了。

c.FileChoose類 :JavaFX的一個(gè)文件選擇器,可以打開本機(jī)的資源管理器,UI美觀與否取決于你的系統(tǒng)版本。

d.CsvReader類 : javacsv-2.0.jar 包下的一個(gè)工具類,主要通過(guò)它來(lái)對(duì)csv文件進(jìn)行操作

e.JTable類:創(chuàng)建一個(gè)JTable實(shí)例做csv文件打開后的展示,需要注意參數(shù)的順序,表格內(nèi)容是一個(gè)二維數(shù)組,表頭是一個(gè)一維數(shù)組

JTable table = new JTable(表格內(nèi)容,表頭);

f. 把一位數(shù)組存進(jìn)一維數(shù)組:

String[][] arr = new String[10][];//開辟一個(gè)10行的二維數(shù)組
String[] row1 = {"id","name","sex","age"};
 
arr[0] = row1;//存進(jìn)二維數(shù)組

g. JTable不顯示表頭:需要把JTable對(duì)象放進(jìn)一個(gè)Pane里

JTable table = new JTable(表內(nèi)容,表頭);
JScrollPane jScrollPane = new JScrollPane(table);
 
SwingNode swingNode = new SwingNode();
swingNode.setContent(jScrollPane);//使用swingNode封裝swing組件,就可以在Javafx中用了

CsvReader的主要方法

  • new CsvReader(String filePath) 初始化構(gòu)造時(shí)需要傳入一個(gè)本地csv文件地址

  • boolean readHeaders() 讀取表頭并跳過(guò)

  • String[] getHeaders() 獲取csv文件表頭(很奇怪,需要readHeaders()方法調(diào)用過(guò)后,才能獲取到,不然報(bào)空指針異常)

也就是這樣:

CsvReader reader = new CsvReader("xxx.csv");
reader.readHeaders(); //沒(méi)有這句話,執(zhí)行下面會(huì)報(bào)錯(cuò)
String[] head = reader.getHeaders();
  • boolean readRecord() 讀取一行csv內(nèi)容,只要你調(diào)用了,下次再調(diào)用就會(huì)切換到csv的下一行,通常我們使用一個(gè)while循環(huán)來(lái)及時(shí)把所有內(nèi)容一行行進(jìn)行操作

  • String getRawRecord() 讀取一行數(shù)據(jù)

while (reader.readRecord()){
    System.out.println(reader.getRawRecord());//輸出一行內(nèi)容
}

實(shí)例 - 讀取本地桌面的一個(gè)csv文件

@Override
    public void start(Stage primaryStage) throws Exception {
        primaryStage.setTitle("文件選擇器");
        primaryStage.setHeight(600);
        primaryStage.setWidth(800);
 
        final FileChooser fileChooser = new FileChooser();
 
        //設(shè)置打開資源管理器后的文件過(guò)濾
        fileChooser.getExtensionFilters().addAll(
                new FileChooser.ExtensionFilter("All Images","*.*"),
                new FileChooser.ExtensionFilter("PNG","*.png"),
                new FileChooser.ExtensionFilter("MP4","*.mp4"),
                new FileChooser.ExtensionFilter("CSV","*.csv")
        );
 
        final Button open = new Button("打開文件");
 
        final GridPane inputGridPane = new GridPane();//創(chuàng)建格子布局面板
        GridPane.setConstraints(open,0,0);//第0行0列
 
        inputGridPane.setHgap(6.0);//設(shè)置水平間距
        inputGridPane.setVgap(6.0);//設(shè)置垂直間距
        inputGridPane.getChildren().addAll(open);//添加按鈕
 
        final Pane rootGroup = new VBox(12);//創(chuàng)建一個(gè)垂直盒子布局器
        rootGroup.getChildren().addAll(inputGridPane);//把格子面板放進(jìn)來(lái)
        rootGroup.setPadding(new Insets(12,12,12,12));
 
        primaryStage.setScene(new Scene(rootGroup));
        primaryStage.show();
 
//設(shè)置點(diǎn)擊-打開文件-的動(dòng)作事件
open.setOnAction(event -> {
            File file = fileChooser.showOpenDialog(primaryStage);//在當(dāng)前窗口打開文件選擇器
            if (file != null){
                try {
                    FileInputStream inputStream = new FileInputStream(file);
                    BufferedInputStream stream = new BufferedInputStream(inputStream);
                    String fileName = file.getName();
                    String filePath = file.getAbsolutePath();
                    System.out.println("文件路徑 = "+filePath);
                    try {
                        CSVDemo.read(filePath);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }    
                    //封裝JTable,使得JTable和Javafx嵌套在一起    
                    SwingNode swingNode = new SwingNode();
                    try {
                        JTable table = read(filePath);
                        JScrollPane jScrollPane = new JScrollPane(table);
                        swingNode.setContent(jScrollPane);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                //設(shè)置JTable打開后表格的相對(duì)位置
                GridPane.setConstraints(swingNode,0,1);
                    inputGridPane.getChildren().add(swingNode);
                } catch (FileNotFoundException e) {
                    e.printStackTrace();
                }
            }
        });
}
//讀取csv文件并把它讀取到JTable中返回
public static JTable read(String filePath) throws IOException {
 
            CsvReader reader = new CsvReader(filePath);
            reader.readHeaders();//跳過(guò)表頭
            String[] head = reader.getHeaders();
 
            List<String []> list = new ArrayList<>();
            String s = reader.getRawRecord();
            System.out.println("表頭 "+s);
            String[] r1 = dataToArray(s);
//            list.add(r1);
 
            while (reader.readRecord()) {
                System.out.println(reader.getRawRecord());
                list.add(dataToArray(reader.getRawRecord()));
            }
        String[][] data = new String[list.size()][];
        System.out.println("一共"+list.size()+"行數(shù)據(jù)");
        for (int i = 0; i < data.length; i++) {
            data[i] = list.get(i);
        }
            JTable table = new JTable(data,head);
            return table;
 
    }
//將每一行的數(shù)據(jù)從String轉(zhuǎn)為String數(shù)組
    public static String[] dataToArray(String row){
        String[] res = row.split(",");
        return res;
    }

效果展示

怎么將Java打開CSV文件到JTable展示

JScrollPane封裝JTable,SwingNode封裝JScrollPane

怎么將Java打開CSV文件到JTable展示

讀到這里,這篇“怎么將Java打開CSV文件到JTable展示”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI