7

我正在尝试使用 Apache Commons CSV 将具有某些标头的 CSV 文件读入 Java 对象。但是,当我运行代码时,我得到以下异常:

Exception in thread "main" java.lang.IllegalArgumentException: Mapping for Color not found, expected one of [Color, Name, Price, House Cost, Rent, 1 House, 2 Houses, 3 Houses, 4 Houses, Hotel, Mortgage]
at org.apache.commons.csv.CSVRecord.get(CSVRecord.java:102)
at GameBoard.<init>(GameBoard.java:25)
at Game.main(Game.java:3)

有人可以解释异常来自哪里吗?在我看来,Apache Commons 不知何故与我的输入不匹配。我有什么问题还是有其他问题?这是我的代码片段:

Reader in;
    Iterable<CSVRecord> records = null;
    try {
        in = new FileReader(new File(Objects.requireNonNull(getClass().getClassLoader().getResource("Properties.csv")).getFile()));
        records = CSVFormat.EXCEL.withFirstRecordAsHeader().parse(in);
    } catch (IOException | NullPointerException e) {
        e.printStackTrace();
        System.exit(1);
    }
    for (CSVRecord record :
            records) {
        spaces.add(new Property(
                record.get("Color"),
                record.get("Name"),
                Integer.parseInt(record.get("Price")),

这是我的 csv 标题(对不起,一个被切断了,但这不是重点): csv 标头

谢谢!

4

3 回答 3

5

我有同样的问题,只有当你引用第一列时才会发生,所有其他列名都在工作。问题是,UTF-8 表示在前面添加了以下字符“0xEF,0xBB,0xBF”(参见Wikipedia page)。这似乎是 commons-csv 的一个已知问题,但由于这是特定于应用程序的,因此无法修复(CSVFormat.EXCEL.parse 应该处理字节顺序标记)。

但是,有一个记录在案的解决方法:

http://commons.apache.org/proper/commons-csv/user-guide.html#Handling_Byte_Order_Marks

于 2020-05-15T08:30:16.567 回答
0

我遇到了同样奇怪的异常。它实际上说“期待......”然后列出它说它找不到的字段 - 就像你的情况一样。

原因是我设置了错误的 CSVFormat:

CSVFormat csvFormat = CSVFormat.newFormat(';');

这意味着我的代码试图在一个实际上有逗号分隔符的文件中用分号分隔字段。

一旦我使用了 DEFAULT CSVFormat,一切都开始工作了。

CSVFormat csvFormat = CSVFormat.DEFAULT;

所以答案是您可能必须为您的文件正确设置 CSVFormat。

于 2019-05-31T14:09:44.780 回答
0

在此处输入图像描述

xyz通过在 CSV 文件中提供不同的标题名称,或者尝试通过调用来获取值,我也得到了相同的异常csvRecord.get("x_z")

我解决了更改标题名称的问题xyz

try {
  fileReader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
  csvParser = new CSVParser(fileReader,
      CSVFormat.DEFAULT.withFirstRecordAsHeader().withIgnoreHeaderCase().withTrim());
  Iterable<CSVRecord> csvRecords = csvParser.getRecords();
  CSVFormat csvFormat = CSVFormat.DEFAULT;
  for (CSVRecord csvRecord : csvRecords) {


} catch (Exception e) {
  System.out.println("Reading CSV Error!");
  e.printStackTrace();
} finally {
  try {
    fileReader.close();
    csvParser.close();
  } catch (IOException e) {
    System.out.println("Closing fileReader/csvParser Error!");
    e.printStackTrace();
  }
}
于 2021-06-09T08:24:57.250 回答