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

org.supercsv.ext.cellprocessor.ParseLocaleDate Maven / Gradle / Ivy

Go to download

CSVのJavaライブラリであるSuperCSVに、アノテーション機能を追加したライブラリです。

There is a newer version: 2.3
Show newest version
/*
 * ParseLocaleDate.java
 * created in 2013/03/06
 *
 * (C) Copyright 2003-2013 GreenDay Project. All rights reserved.
 */
package org.supercsv.ext.cellprocessor;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import java.util.TimeZone;

import org.supercsv.cellprocessor.CellProcessorAdaptor;
import org.supercsv.cellprocessor.ParseDate;
import org.supercsv.cellprocessor.ift.DateCellProcessor;
import org.supercsv.cellprocessor.ift.StringCellProcessor;
import org.supercsv.exception.SuperCsvCellProcessorException;
import org.supercsv.ext.cellprocessor.ift.ValidationCellProcessor;
import org.supercsv.util.CsvContext;


/**
 * 
 * @version 1.0.0
 * @since 1.0.0
 * @see {@link ParseDate}
 * @author T.TSUCHIE
 *
 */
public class ParseLocaleDate  extends CellProcessorAdaptor
        implements StringCellProcessor, ValidationCellProcessor {
    
    protected final String pattern;
    
    protected final boolean lenient;
    
    protected final Locale locale;
    
    protected final TimeZone timeZone;
    
    protected final ThreadLocal formatter = new ThreadLocal() {
        
        @Override
        protected DateFormat initialValue() {
            DateFormat value = new SimpleDateFormat(pattern, locale);
            value.setLenient(lenient);
            
            if(timeZone != null) {
                value.setTimeZone(timeZone);
            }
            
            return value;
        }
    };
    
    public ParseLocaleDate(final String pattern) {
        this(pattern, true, Locale.getDefault(), null);
    }
    
    public ParseLocaleDate(final String pattern, final DateCellProcessor next) {
        this(pattern, true, Locale.getDefault(), null, next);
    }
    
    public ParseLocaleDate(final String pattern, final boolean lenient) {
        this(pattern, lenient, Locale.getDefault(), null);
    }
    
    public ParseLocaleDate(final String pattern, final boolean lenient, final DateCellProcessor next) {
        this(pattern, lenient, Locale.getDefault(), null, next);
    }
    
    /**
     * 
     * @param pattern (required)
     * @param lenient 
     * @param locale
     *          if null, set for {@link Locale#getDefault()} (optional)
     * @param timeZone (optional)
     */
    public ParseLocaleDate(final String pattern, final boolean lenient, final Locale locale, final TimeZone timeZone) {
        super();
        checkPreconditions(pattern);
        this.pattern = pattern;
        this.lenient = lenient;
        this.locale = (locale == null ? Locale.getDefault() : locale);
        this.timeZone = timeZone;
    }
    
    /**
     * 
     * @param pattern
     *          the date format pattern (required).
     * @param lenient
     *          whether date interpretation is lenient.
     * @param locale
     *          the date format locale. if locale is null, use default value with {@link Locale#getDefault()} (optional).
     * @param timeZone
     *          the date format timeZone (optional).
     * @param next
     *          the next processor in the chain (required).
     * @throws IllegalArgumentException
     *          if pattern is null or empty.
     */
    public ParseLocaleDate(final String pattern, final boolean lenient, final Locale locale, final TimeZone timeZone, final DateCellProcessor next) {
        super(next);
        checkPreconditions(pattern);
        this.pattern = pattern;
        this.lenient = lenient;
        this.locale = (locale == null ? Locale.getDefault() : locale);
        this.timeZone = timeZone;
    }
    
    /**
     * Checks the preconditions for creating a new ParseDate processor.
     * @throws IllegalArgumentException
     * 
     */
    protected static void checkPreconditions(final String pattern) {
        if(pattern == null || pattern.isEmpty() ) {
            throw new IllegalArgumentException("pattern should not be null or empty.");
        }
        
    }
    
    /**
     * {@inheritDoc}
     * 
     * @throws SuperCsvCellProcessorException
     *             if value is null, isn't a String, or can't be parsed to a Date.a
     */
    @Override
    public Object execute(final Object value, final CsvContext context) {
        validateInputNotNull(value, context);
        
        if( !(value instanceof String) ) {
            throw new SuperCsvCellProcessorException(String.class, value, context, this);
        }
        
        try {
            Object result = parse((String) value);
            return next.execute(result, context);
            
        } catch(ParseException e) {
            throw new SuperCsvCellProcessorException(String.format("'%s' could not be parsed as a Date", value),
                    context, this, e);
        }
    }
    
    protected Object parse(final String value) throws ParseException {
        
        final Date result = formatter.get().parse(value);
        return result;
    }
    
    public String getPattern() {
        return pattern;
    }
    
    public Locale getLocale() {
        return locale;
    }
    
    public boolean isLenient() {
        return lenient;
    }
    
    public TimeZone getTimeZone() {
        return timeZone;
    }
    
    public ThreadLocal getFormatter() {
        return formatter;
    }
    
    /**
     * {@inheritDoc}
     */
    @Override
    public String getMessageCode() {
        return this.getClass().getCanonicalName() + ".violated";
    }
    
    /**
     * {@inheritDoc}
     */
    @Override
    public Map getMessageVariable() {
        Map vars = new HashMap();
        vars.put("pattern", getPattern());
        vars.put("locale", getLocale());
        vars.put("timeZone", getTimeZone());
        vars.put("lenient", isLenient());
        
        return vars;
    }
    
    /**
     * {@inheritDoc}
     */
    @Override
    public String formatValue(final Object value) {
        if(value == null) {
            return "";
        }
        return value.toString();
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy