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 class
StringCut.CutType
How to cut the string.
-
Field Summary
Fields Modifier and Type Field Description protected Index
m_CharacterEndPos
the character end position.protected Index
m_CharacterStartPos
the character starting position.protected String
m_FieldDelimiter
the field delimiter.protected Index
m_FieldIndex
the field number to extract.protected StringCut.CutType
m_Type
the 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 String
characterEndPosTipText()
Returns the tip text for this property.String
characterStartPosTipText()
Returns the tip text for this property.void
defineOptions()
Adds options to the internal list of options.String
fieldDelimiterTipText()
Returns the tip text for this property.String
fieldIndexTipText()
Returns the tip text for this property.Index
getCharacterEndPos()
Returns the position of the last character to include.Index
getCharacterStartPos()
Returns the position of the first character to include.String
getFieldDelimiter()
Returns the field delimiter in use.Index
getFieldIndex()
Returns the index of the field to cut.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.StringCut.CutType
getType()
Returns the type of cut to perform.String
globalInfo()
Returns a string describing the object.protected void
initialize()
Initializes the members.protected String
process(String s, int index)
Processes the string.void
setCharacterEndPos(Index value)
Sets the position of the last character to include.void
setCharacterStartPos(Index value)
Sets the position of the first character to include.void
setFieldDelimiter(String value)
Sets the field delimiter to use.void
setFieldIndex(Index value)
Sets the index of the field to cut.void
setType(StringCut.CutType value)
Sets the type of cut to perform.String
typeTipText()
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:
globalInfo
in interfaceGlobalInfoSupporter
- Specified by:
globalInfo
in classAbstractOptionHandler
- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptions
in interfaceOptionHandler
- Overrides:
defineOptions
in classAbstractActor
-
initialize
protected void initialize()
Initializes the members.- Overrides:
initialize
in 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:
getQuickInfo
in interfaceActor
- Specified by:
getQuickInfo
in interfaceQuickInfoSupporter
- Overrides:
getQuickInfo
in 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:
process
in 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
-
-