de.siegmar.fastcsv.reader.FieldModifiers Maven / Gradle / Ivy
Show all versions of fastcsv Show documentation
package de.siegmar.fastcsv.reader;
import java.util.Locale;
/**
* Provides some common {@link FieldModifier} implementations.
*
* Example usage:
* {@snippet :
* var modifier = FieldModifiers.TRIM.andThen(FieldModifiers.upper(Locale.ENGLISH));
* var fields = CsvReader.builder()
* .build(new CsvRecordHandler(modifier, " foo , bar"))
* .stream()
* .collect(Collectors.toList());
*
* // fields would be: "FOO" and "BAR"
*}
*/
public final class FieldModifiers {
/**
* Modifier that does not modify anything.
*/
public static final FieldModifier NOP = (SimpleFieldModifier) field -> field;
/**
* Modifier that modifies the field value with {@link String#trim()}.
* Comments are not modified.
*/
public static final FieldModifier TRIM = (SimpleFieldModifier) String::trim;
/**
* Modifier that modifies the field value with {@link String#strip()}.
* Comments are not modified.
*/
public static final FieldModifier STRIP = (SimpleFieldModifier) String::strip;
private FieldModifiers() {
// Utility class
}
/**
* Builds modifier that modifies the field value with {@link String#toLowerCase(Locale)}.
* Comments are not modified.
*
* @param locale use the case transformation rules for this locale
* @return a new field modifier that converts the input to lower case.
*/
public static FieldModifier lower(final Locale locale) {
return (SimpleFieldModifier) field -> field.toLowerCase(locale);
}
/**
* Builds modifier that modifies the field value with {@link String#toUpperCase(Locale)}.
* Comments are not modified.
*
* @param locale use the case transformation rules for this locale
* @return a new field modifier that converts the input to upper case.
*/
public static FieldModifier upper(final Locale locale) {
return (SimpleFieldModifier) field -> field.toUpperCase(locale);
}
}