3

我有一个 csv 文件,我想将它导入到 JTable 中。

是否有一个简单的示例显示如何将 csv 文件导入 JTable?

4

3 回答 3

8

使用 OpenCSV:

CSVReader reader = new CSVReader(new FileReader("yourfile.csv")); 
List myEntries = reader.readAll();
JTable table = new JTable(myEntries.toArray());
于 2012-05-05T21:32:54.967 回答
5

最后一个答案对我不起作用,因为 JTable 想要一个 Object[][] 和一个 String[] (列名)......我不得不做这样的事情:

import com.opencsv.CSVReader;
import java.util.List;
import javax.swing.table.DefaultTableModel;
import javax.swing.JTable; 
import java.io.FileReader;

Object[] columnnames;
transient CSVReader CSVFileReader;
CSVFileReader = new CSVReader(new FileReader(csvFile));
List myEntries = CSVFileReader.readAll();
columnnames = (String[]) myEntries.get(0);
DefaultTableModel tableModel = new DefaultTableModel(columnnames, myEntries.size()-1); 
int rowcount = tableModel.getRowCount();
for (int x = 0; x<rowcount+1; x++)
{
    int columnnumber = 0;
    // if x = 0 this is the first row...skip it... data used for columnnames
    if (x>0)
    {
        for (String thiscellvalue : (String[])myEntries.get(x))
        {
            tableModel.setValueAt(thiscellvalue, x-1, columnnumber);
            columnnumber++;
        }
    }
}

JTable MyJTable = new JTable(tableModel);

此外,如果您想在数据中保留反斜杠字符,请将其用作构造函数:

CSVFileReader = new CSVReader(new FileReader(csvFile), ',', '"', '\0');

这会将“\0”设置为转义字符。我认为这将转义字符设置为空。看到这个线程:opencsv in java ignores backslash in a field value

于 2016-02-18T01:37:16.170 回答
0

如果你想/需要避免使用 CSVReader,你也可以使用 BufferedReader。它当然不像 CSVReader 那样简单。你肯定可以改进它,因为我只是 Java 文件管理的初学者。

这部分是从https://www.youtube.com/watch?v=L2xczUN9aI0上的“JAVA IO - How To Import Text File Data To JTable In Java [ with source code]”中借用的

import java.io.*;
import java.util.*;
import javax.swing.JTable;
import javax.swing.table.*;

public class test {
    public static void main(String[] args) {
        String inputFileName;
        File inputFile;
        String firstRow;
        Vector<Vector<String>> vectorVectorStringsData = new Vector<Vector<String>>();
        Vector<String> vectorStrings = new Vector<String>();
        Vector<String> vectorColumnIdentifiers = new Vector<String>();
        String[] columnIdentifiers;
        DefaultTableModel model = new DefaultTableModel();
        JTable jTable;
        
        inputFileName = "yourFileName.csv";
        inputFile = new File(inputFileName);
        try (FileReader fr = new FileReader(inputFile);
            BufferedReader br = new BufferedReader(fr)) 
        {
            firstRow = br.readLine().trim();
            if (firstRow != null) {
                // headers:
                columnIdentifiers = firstRow.split(",");

                vectorColumnIdentifiers = new Vector<String>();
                for (int j =0; j < columnIdentifiers.length; j++) {
                    vectorColumnIdentifiers.add(columnIdentifiers[j]);
                }
            }
            // rows
            Object[] tableLines = br.lines().toArray();
            // data rows
            for (int i = 0; i < tableLines.length; i++) {
                System.out.println("4");
                String line = tableLines[i].toString().trim();
                String[] dataRow = line.split(",");
                vectorStrings = new Vector<String>();
                for (int j =0; j < dataRow.length; j++) {
                    vectorStrings.add(dataRow[j]);
                }
                vectorVectorStringsData.add(vectorStrings);
            }
            
            fr.close();
        }
        catch (IOException ioe) {
            System.out.println("error: " + ioe.getMessage());
        }

        model.setDataVector(vectorVectorStringsData, vectorColumnIdentifiers);
        jTable = new JTable(model);
    }
}
于 2020-06-22T08:32:00.463 回答