All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.robe.convert.csv.parsers.ParseDate Maven / Gradle / Ivy

package io.robe.convert.csv.parsers;

import org.supercsv.cellprocessor.ift.DateCellProcessor;
import org.supercsv.util.CsvContext;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;

/**
 * Provides a parser for Date. This is a kind of fix for {@link org.supercsv.cellprocessor.ParseDate}.
 */
public class ParseDate extends org.supercsv.cellprocessor.ParseDate {
    private SimpleDateFormat dateFormat;

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format.
     * This constructor uses non-lenient Date interpretation.
     *
     * @param dateFormat the date format to use
     * @throws NullPointerException if dateFormat is null
     */
    public ParseDate(String dateFormat) {
        super(dateFormat);
        this.dateFormat = new SimpleDateFormat(dateFormat);
    }

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format.
     *
     * @param dateFormat the date format to use
     * @param lenient    whether date interpretation is lenient
     * @throws NullPointerException if dateFormat is null
     */
    public ParseDate(String dateFormat, boolean lenient) {
        super(dateFormat, lenient);
        this.dateFormat = new SimpleDateFormat(dateFormat);
    }

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format
     * and Locale.
     *
     * @param dateFormat the date format to use
     * @param lenient    whether date interpretation is lenient
     * @param locale     the Locale used to parse the date
     * @throws NullPointerException if dateFormat or locale is null
     */
    public ParseDate(String dateFormat, boolean lenient, Locale locale) {
        super(dateFormat, lenient, locale);
        this.dateFormat = new SimpleDateFormat(dateFormat);

    }

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format,
     * then calls the next processor in the chain. This constructor uses non-lenient Date interpretation.
     *
     * @param dateFormat the date format to use
     * @param next       the next processor in the chain
     * @throws NullPointerException if dateFormat or next is null
     */
    public ParseDate(String dateFormat, DateCellProcessor next) {
        super(dateFormat, next);
        this.dateFormat = new SimpleDateFormat(dateFormat);

    }

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format,
     * then calls the next processor in the chain.
     *
     * @param dateFormat the date format to use
     * @param lenient    whether date interpretation is lenient
     * @param next       the next processor in the chain
     * @throws NullPointerException if dateFormat or next is null
     */
    public ParseDate(String dateFormat, boolean lenient, DateCellProcessor next) {
        super(dateFormat, lenient, next);
        this.dateFormat = new SimpleDateFormat(dateFormat);

    }

    /**
     * Constructs a new ParseDate processor which converts a String to a Date using the supplied date format
     * and Locale, then calls the next processor in the chain.
     *
     * @param dateFormat the date format to use
     * @param lenient    whether date interpretation is lenient
     * @param locale     the Locale used to parse the date
     * @param next       the next processor in the chain
     * @throws NullPointerException if dateFormat, locale, or next is null
     */
    public ParseDate(String dateFormat, boolean lenient, Locale locale, DateCellProcessor next) {
        super(dateFormat, lenient, locale, next);
        this.dateFormat = new SimpleDateFormat(dateFormat);

    }

    @Override
    public Object execute(Object value, CsvContext context) {
        validateInputNotNull(value, context);

        // FIX: If it is already Date forward it.
        final String result;
        if (value instanceof Date) {
            result = this.dateFormat.format(value);
            return next.execute(result, context);
        } else {
            return super.execute(value, context);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy