Подтвердить что ты не робот

Нет сопоставления заголовков, значения записи не могут быть получены по имени (Apache Commons CSV)

У меня появилось это сообщение об ошибке, когда я пытаюсь прочитать csv:

Exception in thread "main" java.lang.IllegalStateException: No header mapping was specified, the record values can't be accessed by name
at org.apache.commons.csv.CSVRecord.get(CSVRecord.java:99)
at mockdata.MockData.main(MockData.java:33)

Java Результат: 1

Я использую Apache Commons CSV library 1.1. Пробовал пропустить сообщение об ошибке, и единственное, что я получаю, это список кодов на сайтах, таких как grepcode.

Здесь мой код:

package mockdata;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.Reader;
import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVRecord;

public class MockData
{

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) throws FileNotFoundException, IOException
    {
        Reader in = new InputStreamReader(MockData.class.getClassLoader()
                                .getResourceAsStream("MOCK_DATA.csv"), "UTF-8");
        Iterable<CSVRecord> records = CSVFormat.EXCEL.parse(in);
        for (CSVRecord record : records) 
        {
            String lastName = record.get("last_name");
            String firstName = record.get("first_name");

            System.out.println("firstName: " + firstName + " lastName: " + lastName);
        }
    }

}

Содержимое CSV:

first_name,last_name,address1,city,state,zip,country,phone,email
Robin,Lee,668 Kinsman Road,Hagerstown,TX,94913,United States,5-(078)623-0713,[email protected]
Bobby,Moreno,68 Dorton Avenue,Reno,AZ,79934,United States,5-(080)410-6743,[email protected]
Eugene,Alexander,3 Bunker Hill Court,Newark,MS,30066,United States,5-(822)147-6867,[email protected]
Katherine,Crawford,3557 Caliangt Avenue,New Orleans,OR,23289,United States,2-(686)178-7222,[email protected]

Он находится в моей папке src.

4b9b3361

Ответ 1

Вызов метода withHeader() в формат Excel CSV по умолчанию работал у меня:

CSVFormat.EXCEL.withHeader().parse(in);

Образец в документации не очень ясен, но вы можете найти его здесь : Безопасное обращение к столбцам: Если ваш источник содержит запись заголовка, вы можете упростить код и безопасно ссылаться на столбцы, используя withHeader (String...) без аргументов:  CSVFormat.EXCEL.withHeader();