2016-08-25 5 views
1

Я использую версию 3.8 библиотеки OpenCSV. Я использую аннотацию для отображения полей bean-полей в столбцы в файле CSV. Я работаю над этим. Он не работает, когда поле даты пуста.OpenCSV не сопоставляет JavaBeans с аннотациями

java.lang.RuntimeException: Error parsing CSV line: 1 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:483) 
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86) 
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) 
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459) 
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675) 
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) 
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192) 

**Caused by: com.opencsv.exceptions.CsvDataTypeMismatchException** 
at com.opencsv.bean.BeanFieldDate.convertLocaleInspecific(BeanFieldDate.java:216) 
at com.opencsv.bean.BeanFieldDate.convert(BeanFieldDate.java:242) 
at com.opencsv.bean.AbstractBeanField.setFieldValue(AbstractBeanField.java:70) 
at com.opencsv.bean.CsvToBean.processField(CsvToBean.java:245) 
at com.opencsv.bean.CsvToBean.processLine(CsvToBean.java:220) 
at com.opencsv.bean.CsvToBean.processLine(CsvToBean.java:189) 
at com.opencsv.bean.CsvToBean.parse(CsvToBean.java:166) 
... 26 more 
**Caused by: org.apache.commons.beanutils.ConversionException: No value specified for 'Date' 
at** org.apache.commons.beanutils.converters.AbstractConverter.handleMissing(AbstractConverter.java:327) 
at org.apache.commons.beanutils.converters.DateTimeConverter.convertToType(DateTimeConverter.java:327) 
at org.apache.commons.beanutils.converters.AbstractConverter.convert(AbstractConverter.java:169) 
at com.opencsv.bean.BeanFieldDate.convertLocaleInspecific(BeanFieldDate.java:214) 
... 32 more 

Аннотации к конкретному полю bean как «required = false», но он по-прежнему не работает. Вот JavaBean аннотации, где я использую класс java.util.Date:

@CsvBindByName(column="Sent On", required=true) 
@CsvDate(value="MM/dd/yyyy HH:mm:ss a z") 
private Date sentOn; 

@CsvBindByName(column="Last Activity", required=false) 
@CsvDate(value="MM/dd/yyyy HH:mm:ss a z") 
private Date lastActivity; 

@CsvBindByName(column="Completed On", required=false) 
@CsvDate(value="MM/dd/yyyy HH:mm:ss a z") 
private Date completedOn; 

Это, как я создал читатель CSV и анализатор:

final char QUOTE_CHARACTER = '"'; 
    ClassLoader classLoader = getClass().getClassLoader(); 
    File newFile = new File(classLoader.getResource(fileName).getFile()); 
    CSVReader reader2 = null; 

    FileReader fileReader2 = null; 

    List<My_Data> myList = null; 

    try { 

     HeaderColumnNameMappingStrategy<My_Data> strat = new HeaderColumnNameMappingStrategy<My_Data>(); 
     strat.setType(My_Data.class); 

     CsvToBean<My_Data> csv = new CsvToBean<>(); 

     final CSVParser csvParser = new CSVParserBuilder().withSeparator(delimiter) 
                  .withQuoteChar(QUOTE_CHARACTER) 
                  .withStrictQuotes(true) 
                  .build(); 

     fileReader2 = new FileReader(newFile); 

     reader2 = new CSVReaderBuilder(fileReader2).withCSVParser(csvParser) 
                .withVerifyReader(true) 
                .withKeepCarriageReturn(false) 
                .build(); 


     myList = csv.parse(strat, reader2); 

Вот данные файла CSV:

"Subject","Status","Sender Name","Recipient","Sent On","Last Activity","Completed On","Completion Time (DD:HH:MM)","Created Date","Declined Date","Document ID","Reason for Declining","Expiration Date","Date Signed" 
"MyCompany: Plan RCP Endorsements Select Bundle","Sent","ENV_PROD","SANDRA BULLOCK","7/21/2016 10:49:38 AM EST","7/21/2016 10:49:38 AM EST","","","7/21/2016 10:49:37 AM EST","","e05e53d8-e8bd-469e-a774-c0dec98481b2","","9/4/2016 10:49:38 AM EST","" 

Как я обнаружил, что эта ошибка проходит через исходный код. Я надеюсь, что другие сталкиваются с подобной проблемой и могут дать мне предложение о том, как обойти эту проблему. Мне нравится этот подход к сопоставлению, так как это экономит время и силы. Процесс работает, просто прочитав файл в списке. Проблема с этим подходом заключается в том, что я должен написать фабричный процесс для JavaBeans.

Предложения приветствуются.

Спасибо,

Russ

+0

Ошибка, как в случае исключения? Или не работает, как в ожидании. – Compass

+0

Вы проигнорировали заголовок? это кажется ошибкой в ​​строке 1, т. е. заголовок – Saravana

+0

Спасибо за ваше предложение. Когда я пропускаю первую строку, картограф не может найти поле компонента на основе столбца. Случается, что JavaBean создан, но ни одно из полей не заполнено. – rray

ответ

0

Мы определили проблему, вы видите, как вопрос в коде opencsv. Вкладчик переписывает код обработки даты в версии 3.9, поэтому мы убеждаемся, что код исправляет вашу проблему.

Мы не установили дату релиза 3.9, так что если вам нужно что-то сразу и у вас есть или может создать код самостоятельно идти в класс BeanFieldDate и в методе новообращенного и заменить:

if (required && StringUtils.isEmpty(value)) { 
     throw new CsvRequiredFieldEmptyException(); 
    } 

с что-то вроде

if (required && StringUtils.isEmpty(value)) { 
     if (required) { 
      throw new CsvRequiredFieldEmptyException(); 
     } else { 
      return null; // or maybe empty string 
     } 
    } 

и посмотреть, поможет ли это.

+0

Скотт, Спасибо за ваши предложения. Я загрузил исходный код и попробовал их обоих. Это не работает. :-(По той же причине он по-прежнему не работает в одной и той же точке данных. – rray

Смежные вопросы