Package adams.flow.transformer
Class StringCut
-
- All Implemented Interfaces:
AdditionalInformationHandler,CleanUpHandler,Destroyable,GlobalInfoSupporter,LoggingLevelHandler,LoggingSupporter,OptionHandler,QuickInfoSupporter,ShallowCopySupporter<Actor>,SizeOfHandler,Stoppable,StoppableWithFeedback,VariablesInspectionHandler,VariableChangeListener,Actor,ErrorHandler,InputConsumer,OutputProducer,Serializable,Comparable
public class StringCut extends AbstractStringOperation
Cuts out a part of a string. The cut can be either specified as a fixed character position or as a field from delimited columns.
Input/output:
- accepts:
java.lang.String
java.lang.String[]
- generates:
java.lang.String
java.lang.String[]
-logging-level <OFF|SEVERE|WARNING|INFO|CONFIG|FINE|FINER|FINEST> (property: loggingLevel) The logging level for outputting errors and debugging output. default: WARNING
-name <java.lang.String> (property: name) The name of the actor. default: StringCut
-annotation <adams.core.base.BaseAnnotation> (property: annotations) The annotations to attach to this actor. default:
-skip <boolean> (property: skip) If set to true, transformation is skipped and the input token is just forwarded as it is. default: false
-stop-flow-on-error <boolean> (property: stopFlowOnError) If set to true, the flow execution at this level gets stopped in case this actor encounters an error; the error gets propagated; useful for critical actors. default: false
-silent <boolean> (property: silent) If enabled, then no errors are output in the console; Note: the enclosing actor handler must have this enabled as well. default: false
-type <FIELD_DELIMITED|CHARACTER_POSITIONS> (property: type) Determines what type of cut to perform. default: FIELD_DELIMITED
-field-delimiter <java.lang.String> (property: fieldDelimiter) The field delimiter to use; \t gets automatically converted into its character counterpart. default: \\t
-field-index <adams.core.Index> (property: fieldIndex) The 1-based index of the field to cut from the string(s). default: 1 example: An index is a number starting with 1; the following placeholders can be used as well: first, second, third, last_2, last_1, last
-char-start-pos <adams.core.Index> (property: characterStartPos) The position of the first character to include in case fixed character positions are used. default: first example: An index is a number starting with 1; the following placeholders can be used as well: first, second, third, last_2, last_1, last
-char-end-pos <adams.core.Index> (property: characterEndPos) The position of the last character to include in case fixed character positions are used. default: last example: An index is a number starting with 1; the following placeholders can be used as well: first, second, third, last_2, last_1, last
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classStringCut.CutTypeHow to cut the string.
-
Field Summary
Fields Modifier and Type Field Description protected Indexm_CharacterEndPosthe character end position.protected Indexm_CharacterStartPosthe character starting position.protected Stringm_FieldDelimiterthe field delimiter.protected Indexm_FieldIndexthe field number to extract.protected StringCut.CutTypem_Typethe cut type.-
Fields inherited from class adams.flow.transformer.AbstractTransformer
BACKUP_INPUT, BACKUP_OUTPUT, m_InputToken, m_OutputToken
-
Fields inherited from class adams.flow.core.AbstractActor
m_Annotations, m_BackupState, m_DetectedObjectVariables, m_DetectedVariables, m_ErrorHandler, m_Executed, m_Executing, m_ExecutionListeningSupporter, m_FullName, m_LoggingPrefix, m_Name, m_Parent, m_ScopeHandler, m_Self, m_Silent, m_Skip, m_StopFlowOnError, m_StopMessage, m_Stopped, m_StorageHandler, m_VariablesUpdated
-
Fields inherited from class adams.core.option.AbstractOptionHandler
m_OptionManager
-
Fields inherited from class adams.core.logging.LoggingObject
m_Logger, m_LoggingIsEnabled, m_LoggingLevel
-
Fields inherited from interface adams.flow.core.Actor
FILE_EXTENSION, FILE_EXTENSION_GZ
-
-
Constructor Summary
Constructors Constructor Description StringCut()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description StringcharacterEndPosTipText()Returns the tip text for this property.StringcharacterStartPosTipText()Returns the tip text for this property.voiddefineOptions()Adds options to the internal list of options.StringfieldDelimiterTipText()Returns the tip text for this property.StringfieldIndexTipText()Returns the tip text for this property.IndexgetCharacterEndPos()Returns the position of the last character to include.IndexgetCharacterStartPos()Returns the position of the first character to include.StringgetFieldDelimiter()Returns the field delimiter in use.IndexgetFieldIndex()Returns the index of the field to cut.StringgetQuickInfo()Returns a quick info about the actor, which will be displayed in the GUI.StringCut.CutTypegetType()Returns the type of cut to perform.StringglobalInfo()Returns a string describing the object.protected voidinitialize()Initializes the members.protected Stringprocess(String s, int index)Processes the string.voidsetCharacterEndPos(Index value)Sets the position of the last character to include.voidsetCharacterStartPos(Index value)Sets the position of the first character to include.voidsetFieldDelimiter(String value)Sets the field delimiter to use.voidsetFieldIndex(Index value)Sets the index of the field to cut.voidsetType(StringCut.CutType value)Sets the type of cut to perform.StringtypeTipText()Returns the tip text for this property.-
Methods inherited from class adams.flow.transformer.AbstractStringOperation
accepts, doExecute, generates
-
Methods inherited from class adams.flow.transformer.AbstractTransformer
backupState, currentInput, execute, hasInput, hasPendingOutput, input, output, postExecute, restoreState, wrapUp
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, finalUpdateVariables, findVariables, findVariables, forceVariables, forCommandLine, forName, forName, getAdditionalInformation, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowActors, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, handleException, hasErrorHandler, hasStopMessage, index, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, preExecute, pruneBackup, pruneBackup, reset, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged
-
Methods inherited from class adams.core.option.AbstractOptionHandler
cleanUpOptions, finishInit, getDefaultLoggingLevel, getOptionManager, loggingLevelTipText, newOptionManager, setLoggingLevel, toCommandLine, toString
-
Methods inherited from class adams.core.logging.LoggingObject
getLogger, getLoggingLevel, initializeLogging, isLoggingEnabled
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface adams.flow.core.Actor
cleanUp, compareTo, destroy, equals, findVariables, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, hasErrorHandler, hasStopMessage, index, isExecuted, isFinished, isHeadless, isStopped, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, stopExecution, toCommandLine, variableChanged
-
Methods inherited from interface adams.core.AdditionalInformationHandler
getAdditionalInformation
-
Methods inherited from interface adams.core.logging.LoggingLevelHandler
getLoggingLevel, setLoggingLevel
-
Methods inherited from interface adams.core.logging.LoggingSupporter
getLogger, isLoggingEnabled
-
Methods inherited from interface adams.core.option.OptionHandler
cleanUpOptions, getOptionManager
-
Methods inherited from interface adams.core.VariablesInspectionHandler
canInspectOptions
-
-
-
-
Field Detail
-
m_Type
protected StringCut.CutType m_Type
the cut type.
-
m_CharacterStartPos
protected Index m_CharacterStartPos
the character starting position.
-
m_CharacterEndPos
protected Index m_CharacterEndPos
the character end position.
-
m_FieldDelimiter
protected String m_FieldDelimiter
the field delimiter.
-
m_FieldIndex
protected Index m_FieldIndex
the field number to extract.
-
-
Method Detail
-
globalInfo
public String globalInfo()
Returns a string describing the object.- Specified by:
globalInfoin interfaceGlobalInfoSupporter- Specified by:
globalInfoin classAbstractOptionHandler- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptionsin interfaceOptionHandler- Overrides:
defineOptionsin classAbstractActor
-
initialize
protected void initialize()
Initializes the members.- Overrides:
initializein classAbstractActor
-
setType
public void setType(StringCut.CutType value)
Sets the type of cut to perform.- Parameters:
value- the type of cut
-
getType
public StringCut.CutType getType()
Returns the type of cut to perform.- Returns:
- the type of cut
-
typeTipText
public String typeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setCharacterStartPos
public void setCharacterStartPos(Index value)
Sets the position of the first character to include.- Parameters:
value- the starting position
-
getCharacterStartPos
public Index getCharacterStartPos()
Returns the position of the first character to include.- Returns:
- the starting position
-
characterStartPosTipText
public String characterStartPosTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setCharacterEndPos
public void setCharacterEndPos(Index value)
Sets the position of the last character to include.- Parameters:
value- the end position
-
getCharacterEndPos
public Index getCharacterEndPos()
Returns the position of the last character to include.- Returns:
- the end position
-
characterEndPosTipText
public String characterEndPosTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setFieldDelimiter
public void setFieldDelimiter(String value)
Sets the field delimiter to use.- Parameters:
value- the delimiter
-
getFieldDelimiter
public String getFieldDelimiter()
Returns the field delimiter in use.- Returns:
- the delimiter
-
fieldDelimiterTipText
public String fieldDelimiterTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setFieldIndex
public void setFieldIndex(Index value)
Sets the index of the field to cut.- Parameters:
value- the index
-
getFieldIndex
public Index getFieldIndex()
Returns the index of the field to cut.- Returns:
- the index
-
fieldIndexTipText
public String fieldIndexTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfoin interfaceActor- Specified by:
getQuickInfoin interfaceQuickInfoSupporter- Overrides:
getQuickInfoin classAbstractActor- Returns:
- null if no info available, otherwise short string
-
process
protected String process(String s, int index)
Processes the string. If null is returned, this output will be ignored.- Specified by:
processin classAbstractStringOperation- Parameters:
s- the string to processindex- the 0-based index of the string currently being processed- Returns:
- the processed string or null if nothing produced
-
-