Как разобрать не строковые значения в Opencsv HeaderColumnNameMappingStrategy - PullRequest
2 голосов
/ 30 ноября 2011

Я использую HeaderColumnNameMappingStrategy для сопоставления CSV-файла с заголовком в JavaBean.Строковые значения разбираются нормально, но любое значение «истина» или «ложь» в csv не отображается на JavaBean, и я получаю следующее исключение из PropertyDescriptor:

java.lang.IllegalArgumentException: argument type mismatch

Код, в котором это происходит, находится в CsvToBean,строка 64:

protected T processLine(MappingStrategy<T> mapper, String[] line) throws  
 IllegalAccessException, InvocationTargetException, InstantiationException, IntrospectionException {
    T bean = mapper.createBean();
    for(int col = 0; col < line.length; col++) {
        String value = line[col];
        PropertyDescriptor prop = mapper.findDescriptor(col);
        if (null != prop) {
            Object obj = convertValue(value, prop);
            // this is where exception is thrown for a "true" value in csv
            prop.getWriteMethod().invoke(bean, new Object[] {obj});
        }
    }
    return bean;
}

 protected PropertyEditor getPropertyEditor(PropertyDescriptor desc) throws   
       InstantiationException, IllegalAccessException {
    Class<?> cls = desc.getPropertyEditorClass();
    if (null != cls) return (PropertyEditor) cls.newInstance();
    return getPropertyEditorValue(desc.getPropertyType());
}

Я могу подтвердить (с помощью отладчика), что идентификатор метода установки правильно получен в этой точке.

Проблема возникает в desc.getPropertyEditorClass (), так как он возвращает ноль.Я предполагал, что примитивные типы и его оболочки поддерживаются.Разве они не?

Ответы [ 3 ]

5 голосов
/ 14 сентября 2012

Я столкнулся с этой же проблемой. Самый простой способ - это переопределить getPropertyEditor, как это делала pritam выше, и вернуть собственный PropertyEditor для вашего конкретного объекта. Быстрый и грязный способ - переопределить convertValue в анонимной форме класса, например:

CsvToBean<MyClass> csvToBean = new CsvToBean<MyClass>(){

    @Override
    protected Object convertValue(String value, PropertyDescriptor prop) throws InstantiationException,IllegalAccessException {

        if (prop.getName().equals("myWhatever")) {
            // return an custom object based on the incoming value
            return new MyWhatever((String)value);
        }

        return super.convertValue(value, prop);
    }
};

Это нормально работает с OpenCSV 2.3. Удачи!

1 голос
/ 01 декабря 2011

Я решил эту проблему, расширив CsvToBean и добавив свои собственные PropertyEditors. Оказывается, opencsv просто поддерживает примитивные типы и не содержит оболочек.

0 голосов
/ 28 ноября 2018

Ответ Притама великолепен, и это пример работы с форматом даты и времени.
PropertyEditorManager.registerEditor(java.util.Date.class, DateEditor.class);
Вы должны написать свой собственный класс редактора, например:
public class DateEditor extends PropertyEditorSupport{ public static final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); @Override public void setAsText(String text){ setValue(sdf.parse(text));} }

...