有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java UNIVOCITYPARSERS for csv to bean对象在发生错误时立即停止

我正在使用UNIVOCITY-Parser将csv文件行转换为java对象

在处理文件时,如果它遇到任何问题(行中的任何列),则它将在该行停止解析并引发异常。但我需要的东西,将继续到文件的结尾只是跳过有错误的行。但是我在api中没有任何实用程序类

我的豆子课

public class ItemcodeBean {

@Trim
@NullString(nulls = { " ", "" }) 
@Parsed(field = "ItemCode")
 private String itemCode;

@Trim 
@NullString(nulls = { " ", "" })
@Parsed(field = "PartNumber") 
private String partNumber;

@Trim 
@NullString(nulls = { " ", "" }) 
@Parsed(field = "ModelNumber") 
private String modelNumber;

}

我的主课

public class TestClass {

    private  BeanListProcessor<ItemcodeBean>
            rowProcessor = null;
    private CsvParser parser = null;
    public static void main(String[] args) {
        TestClass testClass = new TestClass();
        testClass.init();
        try{
            ItemcodeBean itemcodeBean;
            while ((itemcodeBean = testClass.getRowData()) != null){
                System.out.println(itemcodeBean.toString());
            }
        }catch (Throwable ex){
            System.out.println(ex.getLocalizedMessage());
        }

    }

    private BeanListProcessor<ItemcodeBean> init() {
        // BeanListProcessor converts each parsed row to an instance of a given class, then stores each instance into a list.
              this.rowProcessor =
                new BeanListProcessor<ItemcodeBean>(ItemcodeBean.class);

        CsvParserSettings parserSettings = new CsvParserSettings();
        parserSettings.setProcessor(rowProcessor);
        parserSettings.setHeaderExtractionEnabled(true);
        // skip leading whitespaces
        parserSettings.setIgnoreLeadingWhitespaces(true);

        //skip trailing whitespaces
        parserSettings.setIgnoreTrailingWhitespaces(true);
        //skip empty lines
        parserSettings.setSkipEmptyLines(true);

        File file = new File("C:\\Users\\abhishyam.c\\Downloads\\Itemcode_Template.csv");
        this.parser = new CsvParser(parserSettings);
        //parser.parse(file);
        parser.beginParsing(file);
        return rowProcessor;
    }

    private ItemcodeBean getRowData() throws Throwable {
        String[] row;
        try {
            while ((row = parser.parseNext()) != null){
                return rowProcessor.createBean(row, parser.getContext());
            }
        }catch (DataProcessingException e){
            throw new DataProcessingException(e.getColumnName(),e);
        }
       // parser.stopParsing();
        return null;
    }
}

共 (1) 个答案

  1. # 1 楼答案

    只需使用错误处理程序,它将继续运行,除非您自己抛出异常:

        //Let's set a RowProcessorErrorHandler to log the error. The parser will keep running.
        settings.setProcessorErrorHandler(new RowProcessorErrorHandler() {
            @Override
            public void handleError(DataProcessingException error, Object[] inputRow, ParsingContext context) {
                println(out, "Error processing row: " + Arrays.toString(inputRow));
                println(out, "Error details: column '" + error.getColumnName() + "' (index " + error.getColumnIndex() + ") has value '" + inputRow[error.getColumnIndex()] + "'");
            }
        });
    

    更新:您可以使用RetryableErrorHandler来防止丢弃该行。这是版本2.3.0中添加的一个特殊实现,允许用户调用方法setDefaultValue()为有问题的列赋值,并keepRecord防止丢弃记录

    例如:

    settings.setProcessorErrorHandler(new RetryableErrorHandler<ParsingContext>() {
        @Override
        public void handleError(DataProcessingException error, Object[] inputRow, ParsingContext context) {
            //if there's an error in the first column, assign 50 and proceed with the record.
            if (error.getColumnIndex() == 0) { 
                setDefaultValue(50);
            } else { //else keep the record anyway. Null will be used instead.
                keepRecord();
            }
        }
    });
    

    请注意,如果error.getColumnIndex()返回-1,则无法执行任何操作来保存记录,并且不管怎样都将跳过该记录。您可以使用它来记录错误详细信息