This class defines new groovy methods which appear on String-related JDK
classes (String, CharSequence, Matcher) inside the Groovy environment.
Static methods are used with the
first parameter being the destination class,
e.g.. public static String reverse(String self)
provides a reverse()
method for String
.
NOTE: While this class contains many 'public' static methods, it is primarily regarded as an internal class (its internal package name suggests this also). We value backwards compatibility of these methods when used within Groovy but value less backwards compatibility at the Java method call level. I.e. future versions of Groovy may remove or move a method call in this file but would normally aim to keep the method available from within Groovy.
Type | Name and description |
---|---|
static boolean |
asBoolean(CharSequence string) Coerce a string (an instance of CharSequence) to a boolean value. |
static boolean |
asBoolean(Matcher matcher) Coerce a Matcher instance to a boolean value. |
static T |
asType(CharSequence self, Class<T> c) |
static T |
asType(GString self, Class<T> c) Converts the GString to a File, or delegates to the default DefaultGroovyMethods.asType |
static T |
asType(String self, Class<T> c) Provides a method to perform custom 'dynamic' type conversion to the given class using the as operator.
|
static Pattern |
bitwiseNegate(CharSequence self) Turns a CharSequence into a regular expression Pattern |
static Pattern |
bitwiseNegate(String self) Turns a String into a regular expression Pattern |
static CharSequence |
capitalize(CharSequence self) Convenience method to capitalize the first letter of a CharSequence. |
static String |
capitalize(String self) Convenience method to capitalize the first letter of a string (typically the first letter of a word). |
static CharSequence |
center(CharSequence self, Number numberOfChars) Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered. |
static CharSequence |
center(CharSequence self, Number numberOfChars, CharSequence padding) Pad a CharSequence to a minimum length specified by numberOfChars, appending the supplied padding CharSequence around the original as many times as needed keeping it centered. |
static String |
center(String self, Number numberOfChars) Pad a String to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered. |
static String |
center(String self, Number numberOfChars, String padding) Pad a String to a minimum length specified by numberOfChars, appending the supplied padding String around the original as many times as needed keeping it centered. |
static String |
collectReplacements(String orig, Closure<String> transform) Iterate through this String a character at a time collecting either the original character or a transformed replacement String. |
static boolean |
contains(CharSequence self, CharSequence text) Provide an implementation of contains() like Collection.contains to make CharSequences more polymorphic. |
static boolean |
contains(String self, String text) Provide an implementation of contains() like Collection.contains to make Strings more polymorphic. |
static int |
count(CharSequence self, CharSequence text) Count the number of occurrences of a sub CharSequence. |
static int |
count(String self, String text) Count the number of occurrences of a substring. |
static CharSequence |
denormalize(CharSequence self) Return a CharSequence with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator. |
static String |
denormalize(String self) Return a String with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator. |
static CharSequence |
drop(CharSequence self, int num) Drops the given number of chars from the head of this CharSequence if they are available. |
static CharSequence |
dropWhile(CharSequence self, Closure condition) Create a suffix of the given CharSequence by dropping as many characters as possible from the front of the original CharSequence such that calling the given closure condition evaluates to true when passed each of the dropped characters. |
static T |
eachLine(CharSequence self, Closure<T> closure) Iterates through this CharSequence line by line. |
static T |
eachLine(CharSequence self, int firstLine, Closure<T> closure) Iterates through this CharSequence line by line. |
static T |
eachLine(String self, Closure<T> closure) Iterates through this String line by line. |
static T |
eachLine(String self, int firstLine, Closure<T> closure) Iterates through this String line by line. |
static String |
eachMatch(CharSequence self, CharSequence regex, Closure closure) Process each regex group matched substring of the given CharSequence. |
static String |
eachMatch(CharSequence self, Pattern pattern, Closure closure) Process each regex group matched substring of the given pattern. |
static String |
eachMatch(String self, Pattern pattern, Closure closure) Process each regex group matched substring of the given pattern. |
static String |
eachMatch(String self, String regex, Closure closure) Process each regex group matched substring of the given string. |
static CharSequence |
expand(CharSequence self) Expands all tabs into spaces with tabStops of size 8. |
static CharSequence |
expand(CharSequence self, int tabStop) Expands all tabs into spaces. |
static String |
expand(String self) Expands all tabs into spaces with tabStops of size 8. |
static String |
expand(String self, int tabStop) Expands all tabs into spaces. |
static CharSequence |
expandLine(CharSequence self, int tabStop) Expands all tabs into spaces. |
static String |
expandLine(String self, int tabStop) Expands all tabs into spaces. |
static CharSequence |
find(CharSequence self, CharSequence regex) Finds the first occurrence of a regular expression CharSequence within a CharSequence. |
static CharSequence |
find(CharSequence self, CharSequence regex, Closure closure) Returns the result of calling a closure with the first occurrence of a regular expression found within a CharSequence. |
static CharSequence |
find(CharSequence self, Pattern pattern) Finds the first occurrence of a compiled regular expression Pattern within a CharSequence. |
static CharSequence |
find(CharSequence self, Pattern pattern, Closure closure) Returns the result of calling a closure with the first occurrence of a regular expression found within a CharSequence. If the regex doesn't match, the closure will not be called and find will return null. |
static String |
find(String self, Pattern pattern) Finds the first occurrence of a compiled regular expression Pattern within a String. |
static String |
find(String self, Pattern pattern, Closure closure) Returns the result of calling a closure with the first occurrence of a compiled regular expression found within a String. |
static String |
find(String self, String regex) Finds the first occurrence of a regular expression String within a String. |
static String |
find(String self, String regex, Closure closure) Returns the result of calling a closure with the first occurrence of a regular expression found within a String. |
static List<CharSequence> |
findAll(CharSequence self, CharSequence regex) Returns a (possibly empty) list of all occurrences of a regular expression (in CharSequence format) found within a CharSequence. |
static List<T> |
findAll(CharSequence self, CharSequence regex, Closure<T> closure) Finds all occurrences of a capturing regular expression CharSequence within a CharSequence. |
static List<CharSequence> |
findAll(CharSequence self, Pattern pattern) Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a CharSequence. |
static List<T> |
findAll(CharSequence self, Pattern pattern, Closure<T> closure) Finds all occurrences of a compiled regular expression Pattern within a CharSequence. |
static List<String> |
findAll(String self, Pattern pattern) Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a String. |
static List<T> |
findAll(String self, Pattern pattern, Closure<T> closure) Finds all occurrences of a compiled regular expression Pattern within a String. |
static List<String> |
findAll(String self, String regex) Returns a (possibly empty) list of all occurrences of a regular expression (in String format) found within a String. |
static List<T> |
findAll(String self, String regex, Closure<T> closure) Finds all occurrences of a regular expression string within a String. |
static CharSequence |
getAt(CharSequence self, Collection indices) Select a List of characters from a CharSequence using a Collection to identify the indices to be selected. |
static CharSequence |
getAt(CharSequence text, EmptyRange range) Support the range subscript operator for CharSequence or StringBuffer with EmptyRange |
static CharSequence |
getAt(CharSequence text, int index) Support the subscript operator for CharSequence. |
static CharSequence |
getAt(CharSequence text, IntRange range) Support the range subscript operator for CharSequence or StringBuffer with IntRange |
static CharSequence |
getAt(CharSequence text, Range range) Support the range subscript operator for CharSequence |
static List |
getAt(Matcher self, Collection indices) Select a List of values from a Matcher using a Collection to identify the indices to be selected. |
static Object |
getAt(Matcher matcher, int idx) Support the subscript operator, e.g. matcher[index], for a regex Matcher. |
static String |
getAt(String self, Collection indices) Select a List of characters from a String using a Collection to identify the indices to be selected. |
static String |
getAt(String text, EmptyRange range) Support the range subscript operator for String with EmptyRange |
static String |
getAt(String text, int index) Support the subscript operator for String. |
static String |
getAt(String text, IntRange range) Support the range subscript operator for String with IntRange |
static String |
getAt(String text, Range range) Support the range subscript operator for String |
static char[] |
getChars(CharSequence self) Converts the given CharSequence into an array of characters. |
static char[] |
getChars(String self) Converts the given String into an array of characters. |
static int |
getCount(Matcher matcher) Find the number of Strings matched to the given Matcher. |
static boolean |
hasGroup(Matcher matcher) Check whether a Matcher contains a group or not. |
static boolean |
isAllWhitespace(CharSequence self) True if a CharSequence only contains whitespace characters. |
static boolean |
isAllWhitespace(String self) True if a String only contains whitespace characters. |
static boolean |
isBigDecimal(CharSequence self) Determine if a CharSequence can be parsed as a BigDecimal. |
static boolean |
isBigDecimal(String self) Determine if a String can be parsed into a BigDecimal. |
static boolean |
isBigInteger(CharSequence self) Determine if a CharSequence can be parsed as a BigInteger. |
static boolean |
isBigInteger(String self) Determine if a String can be parsed into a BigInteger. |
static boolean |
isCase(CharSequence caseValue, Object switchValue) 'Case' implementation for a CharSequence, which simply calls the equivalent method for String. |
static boolean |
isCase(GString caseValue, Object switchValue) 'Case' implementation for a GString, which simply calls the equivalent method for String. |
static boolean |
isCase(Pattern caseValue, Object switchValue) 'Case' implementation for the Pattern class, which allows testing a String against a number of regular expressions. |
static boolean |
isCase(String caseValue, Object switchValue) 'Case' implementation for a String, which uses String#equals(Object) in order to allow Strings to be used in switch statements. |
static boolean |
isDouble(CharSequence self) Determine if a CharSequence can be parsed as a Double. |
static boolean |
isDouble(String self) Determine if a String can be parsed into a Double. |
static boolean |
isFloat(CharSequence self) Determine if a CharSequence can be parsed as a Float. |
static boolean |
isFloat(String self) Determine if a String can be parsed into a Float. |
static boolean |
isInteger(CharSequence self) Determine if a CharSequence can be parsed as an Integer. |
static boolean |
isInteger(String self) Determine if a String can be parsed into an Integer. |
static boolean |
isLong(CharSequence self) Determine if a CharSequence can be parsed as a Long. |
static boolean |
isLong(String self) Determine if a String can be parsed into a Long. |
static boolean |
isNumber(CharSequence self) Determine if a CharSequence can be parsed as a Number. |
static boolean |
isNumber(String self) Determine if a String can be parsed into a Number. |
static Iterator |
iterator(Matcher matcher) Returns an Iterator which traverses each match. |
static StringBuilder |
leftShift(CharSequence self, Object value) Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a CharSequence. |
static StringBuffer |
leftShift(String self, Object value) Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a String. |
static StringBuffer |
leftShift(StringBuffer self, Object value) Overloads the left shift operator to provide an easy way to append multiple objects as string representations to a StringBuffer. |
static StringBuilder |
leftShift(StringBuilder self, Object value) Overloads the left shift operator to provide syntactic sugar for appending to a StringBuilder. |
static boolean |
matches(CharSequence self, Pattern pattern) Tells whether or not a CharSequence matches the given compiled regular expression Pattern. |
static boolean |
matches(String self, Pattern pattern) Tells whether or not self matches the given compiled regular expression Pattern. |
static boolean |
matchesPartially(Matcher matcher) Given a matcher that matches a string against a pattern, this method returns true when the string matches the pattern or if a longer string, could match the pattern. |
static CharSequence |
minus(CharSequence self, Object target) Remove a part of a CharSequence by replacing the first occurrence of target within self with '' and returns the result. |
static String |
minus(String self, Pattern pattern) Remove a part of a String. |
static String |
minus(String self, Object target) Remove a part of a String. |
static CharSequence |
multiply(CharSequence self, Number factor) Repeat a CharSequence a certain number of times. |
static String |
multiply(String self, Number factor) Repeat a String a certain number of times. |
static CharSequence |
next(CharSequence self) This method is called by the ++ operator for the class CharSequence. |
static String |
next(String self) This method is called by the ++ operator for the class String. |
static CharSequence |
normalize(CharSequence self) Return a CharSequence with linefeeds and carriage returns normalized to linefeeds. |
static String |
normalize(String self) Return a String with linefeeds and carriage returns normalized to linefeeds. |
static CharSequence |
padLeft(CharSequence self, Number numberOfChars) Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed. |
static CharSequence |
padLeft(CharSequence self, Number numberOfChars, CharSequence padding) Pad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the left. |
static String |
padLeft(String self, Number numberOfChars) Pad a String to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed. |
static String |
padLeft(String self, Number numberOfChars, String padding) Pad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the left. |
static CharSequence |
padRight(CharSequence self, Number numberOfChars) Pad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed. |
static CharSequence |
padRight(CharSequence self, Number numberOfChars, CharSequence padding) Pad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the right. |
static String |
padRight(String self, Number numberOfChars) Pad a String to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed. |
static String |
padRight(String self, Number numberOfChars, String padding) Pad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the right. |
static CharSequence |
plus(CharSequence left, Object value) Appends the String representation of the given operand to this string. |
static String |
plus(Number value, String right) Appends a String to the string representation of this number. |
static String |
plus(String left, Object value) Appends the String representation of the given operand to this string. |
static String |
plus(String left, CharSequence value) Appends the String representation of the given operand to this string. |
static String |
plus(StringBuffer left, String value) Appends a String to this StringBuffer. |
static CharSequence |
previous(CharSequence self) This method is called by the -- operator for the class CharSequence. |
static String |
previous(String self) This method is called by the -- operator for the class String. |
static void |
putAt(StringBuffer self, EmptyRange range, Object value) Support the range subscript operator for StringBuffer. |
static void |
putAt(StringBuffer self, IntRange range, Object value) Support the range subscript operator for StringBuffer. |
static List<CharSequence> |
readLines(CharSequence self) Return the lines of a CharSequence as a List of CharSequence. |
static List<String> |
readLines(String self) Return the lines of a String as a List of Strings. |
static CharSequence |
replaceAll(CharSequence self, CharSequence regex, CharSequence replacement) Replaces each substring of this CharSequence that matches the given regular expression with the given replacement. |
static CharSequence |
replaceAll(CharSequence self, CharSequence regex, Closure closure) Replaces all occurrences of a captured group by the result of a closure on that text. |
static CharSequence |
replaceAll(CharSequence self, Pattern pattern, CharSequence replacement) Replaces all substrings of a CharSequence that match the given compiled regular expression with the given replacement. |
static String |
replaceAll(CharSequence self, Pattern pattern, Closure closure) Replaces all occurrences of a captured group by the result of a closure call on that text. |
static String |
replaceAll(String self, Pattern pattern, Closure closure) Replaces all occurrences of a captured group by the result of a closure call on that text. |
static String |
replaceAll(String self, Pattern pattern, String replacement) Replaces all substrings of a String that match the given compiled regular expression with the given replacement. |
static String |
replaceAll(String self, String regex, Closure closure) Replaces all occurrences of a captured group by the result of a closure on that text. |
static String |
replaceFirst(CharSequence self, CharSequence regex, CharSequence replacement) Replaces the first substring of this CharSequence that matches the given regular expression with the given replacement. |
static String |
replaceFirst(CharSequence self, CharSequence regex, Closure closure) Replaces the first occurrence of a captured group by the result of a closure call on that text. |
static CharSequence |
replaceFirst(CharSequence self, Pattern pattern, CharSequence replacement) Replaces the first substring of a CharSequence that matches the given compiled regular expression with the given replacement. |
static String |
replaceFirst(CharSequence self, Pattern pattern, Closure closure) Replaces the first occurrence of a captured group by the result of a closure call on that text. |
static String |
replaceFirst(String self, Pattern pattern, Closure closure) Replaces the first occurrence of a captured group by the result of a closure call on that text. |
static String |
replaceFirst(String self, Pattern pattern, String replacement) Replaces the first substring of a String that matches the given compiled regular expression with the given replacement. |
static String |
replaceFirst(String self, String regex, Closure closure) Replaces the first occurrence of a captured group by the result of a closure call on that text. |
static CharSequence |
reverse(CharSequence self) Creates a new CharSequence which is the reverse (backwards) of this string |
static String |
reverse(String self) Creates a new string which is the reverse (backwards) of this string |
static void |
setIndex(Matcher matcher, int idx) Set the position of the given Matcher to the given index. |
static int |
size(CharSequence text) Provide the standard Groovy size() method for CharSequence . |
static long |
size(Matcher self) Provide the standard Groovy size() method for Matcher . |
static int |
size(String text) Provide the standard Groovy size() method for String . |
static int |
size(StringBuffer buffer) Provide the standard Groovy size() method for StringBuffer . |
static CharSequence[] |
split(CharSequence self) Convenience method to split a CharSequence (with whitespace as delimiter). |
static String[] |
split(GString self) Convenience method to split a GString (with whitespace as delimiter). |
static String[] |
split(String self) Convenience method to split a string (with whitespace as delimiter) Like tokenize, but returns an Array of Strings instead of a List |
static T |
splitEachLine(CharSequence self, CharSequence regex, Closure<T> closure) Iterates through the given CharSequence line by line, splitting each line using the given separator. |
static T |
splitEachLine(CharSequence self, Pattern pattern, Closure<T> closure) Iterates through the given CharSequence line by line, splitting each line using the given separator Pattern. |
static T |
splitEachLine(String self, Pattern pattern, Closure<T> closure) Iterates through the given String line by line, splitting each line using the given separator Pattern. |
static T |
splitEachLine(String self, String regex, Closure<T> closure) Iterates through the given String line by line, splitting each line using the given separator. |
static CharSequence |
stripIndent(CharSequence self) Strip leading spaces from every line in a CharSequence. |
static CharSequence |
stripIndent(CharSequence self, int numChars) Strip numChar leading characters from every line in a CharSequence. |
static String |
stripIndent(String self) Strip leading spaces from every line in a String. |
static String |
stripIndent(String self, int numChars) Strip numChar leading characters from every line in a String. |
static CharSequence |
stripMargin(CharSequence self) Strip leading whitespace/control characters followed by '|' from every line in a CharSequence. |
static CharSequence |
stripMargin(CharSequence self, char marginChar) Strip leading whitespace/control characters followed by marginChar from every line in a String. |
static String |
stripMargin(CharSequence self, CharSequence marginChar) Strip leading whitespace/control characters followed by marginChar from every line in a CharSequence. |
static String |
stripMargin(String self) Strip leading whitespace/control characters followed by '|' from every line in a String. |
static String |
stripMargin(String self, char marginChar) Strip leading whitespace/control characters followed by marginChar from every line in a String. |
static String |
stripMargin(String self, String marginChar) Strip leading whitespace/control characters followed by marginChar from every line in a String. |
static CharSequence |
take(CharSequence self, int num) Returns the first num elements from this CharSequence.
|
static CharSequence |
takeWhile(CharSequence self, Closure condition) Returns the longest prefix of this CharSequence where each element passed to the given closure evaluates to true. |
static BigDecimal |
toBigDecimal(CharSequence self) Parse a CharSequence into a BigDecimal |
static BigDecimal |
toBigDecimal(String self) Parse a String into a BigDecimal |
static BigInteger |
toBigInteger(CharSequence self) Parse a CharSequence into a BigInteger |
static BigInteger |
toBigInteger(String self) Parse a String into a BigInteger |
static Boolean |
toBoolean(String self) Converts the given string into a Boolean object. |
static Character |
toCharacter(String self) Converts the given string into a Character object using the first character in the string. |
static Double |
toDouble(CharSequence self) Parse a CharSequence into a Double |
static Double |
toDouble(String self) Parse a String into a Double |
static Float |
toFloat(CharSequence self) Parse a CharSequence into a Float |
static Float |
toFloat(String self) Parse a String into a Float |
static Integer |
toInteger(CharSequence self) Parse a CharSequence into an Integer |
static Integer |
toInteger(String self) Parse a String into an Integer |
static List<CharSequence> |
toList(CharSequence self) Converts the given CharSequence into a List of CharSequence of one character. |
static List<String> |
toList(String self) Converts the given String into a List of strings of one character. |
static Long |
toLong(CharSequence self) Parse a CharSequence into a Long |
static Long |
toLong(String self) Parse a String into a Long |
static Set<CharSequence> |
toSet(CharSequence self) Converts the given CharSequence into a Set of unique CharSequence of one character. |
static Set<String> |
toSet(String self) Converts the given String into a Set of unique strings of one character. |
static Short |
toShort(CharSequence self) Parse a CharSequence into a Short |
static Short |
toShort(String self) Parse a String into a Short |
static List<CharSequence> |
tokenize(CharSequence self) Tokenize a CharSequence (with a whitespace as the delimiter). |
static List<CharSequence> |
tokenize(CharSequence self, Character token) Tokenize a CharSequence based on the given character delimiter. |
static List<CharSequence> |
tokenize(CharSequence self, CharSequence token) Tokenize a CharSequence based on the given CharSequence delimiter. |
static List<String> |
tokenize(String self) Tokenize a String (with a whitespace as the delimiter). |
static List<String> |
tokenize(String self, Character token) Tokenize a String based on the given character delimiter. |
static List<String> |
tokenize(String self, String token) Tokenize a String based on the given string delimiter. |
static CharSequence |
tr(CharSequence self, CharSequence sourceSet, CharSequence replacementSet) Translates a string by replacing characters from the sourceSet with characters from replacementSet. |
static String |
tr(String self, String sourceSet, String replacementSet) Translates a string by replacing characters from the sourceSet with characters from replacementSet. |
static CharSequence |
unexpand(CharSequence self) Replaces sequences of whitespaces with tabs using tabStops of size 8. |
static CharSequence |
unexpand(CharSequence self, int tabStop) Replaces sequences of whitespaces with tabs. |
static String |
unexpand(String self) Replaces sequences of whitespaces with tabs using tabStops of size 8. |
static String |
unexpand(String self, int tabStop) Replaces sequences of whitespaces with tabs. |
static CharSequence |
unexpandLine(CharSequence self, int tabStop) Replaces sequences of whitespaces with tabs within a line. |
static String |
unexpandLine(String self, int tabStop) Replaces sequences of whitespaces with tabs within a line. |
Methods inherited from class | Name |
---|---|
class DefaultGroovyMethodsSupport |
cloneSimilarCollection, cloneSimilarMap, closeQuietly, closeWithWarning, createSimilarArray, createSimilarCollection, createSimilarCollection, createSimilarList, createSimilarMap, createSimilarOrDefaultCollection, createSimilarSet, normaliseIndex, sameType, subListBorders, subListBorders |
class Object |
wait, wait, wait, equals, toString, hashCode, getClass, notify, notifyAll |
Coerce a string (an instance of CharSequence) to a boolean value. A string is coerced to false if it is of length 0, and to true otherwise.
string
- the character sequenceCoerce a Matcher instance to a boolean value.
matcher
- the matcher
Provides a method to perform custom 'dynamic' type conversion
to the given class using the as
operator.
self
- a CharSequencec
- the desired classConverts the GString to a File, or delegates to the default DefaultGroovyMethods.asType
self
- a GStringc
- the desired class Provides a method to perform custom 'dynamic' type conversion
to the given class using the as
operator.
Example: '123' as Double
By default, the following types are supported:
self
- a Stringc
- the desired classTurns a CharSequence into a regular expression Pattern
self
- a String to convert into a regular expressionTurns a String into a regular expression Pattern
self
- a String to convert into a regular expressionConvenience method to capitalize the first letter of a CharSequence.
self
- The CharSequence to capitalizeConvenience method to capitalize the first letter of a string (typically the first letter of a word). Example usage:
assert 'h'.capitalize() == 'H' assert 'hello'.capitalize() == 'Hello' assert 'hello world'.capitalize() == 'Hello world' assert 'Hello World' == 'hello world'.split(' ').collect{ it.capitalize() }.join(' ')
self
- The string to capitalizePad a CharSequence to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencePad a CharSequence to a minimum length specified by numberOfChars, appending the supplied padding CharSequence around the original as many times as needed keeping it centered.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for paddingPad a String to a minimum length specified by numberOfChars by adding the space character around it as many times as needed so that it remains centered. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
['A', 'BB', 'CCC', 'DDDD'].each{ println '|' + it.center(6) + '|' }will produce output like:
| A | | BB | | CCC | | DDDD |
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringPad a String to a minimum length specified by numberOfChars, appending the supplied padding String around the original as many times as needed keeping it centered. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
['A', 'BB', 'CCC', 'DDDD'].each{ println '|' + it.center(6, '+') + '|' }will produce output like:
|++A+++| |++BB++| |+CCC++| |+DDDD+|
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for padding Iterate through this String a character at a time collecting either the
original character or a transformed replacement String. The transform
Closure should return null
to indicate that no transformation is
required for the given character.
assert "Groovy".collectReplacements{ it == 'o' ? '_O_' : null } == 'Gr_O__O_vy' assert "B&W".collectReplacements{ it == '&' ? '&' : null } == 'B&W'
orig
- the original Stringtransform
Closure.Provide an implementation of contains() like Collection.contains to make CharSequences more polymorphic.
self
- a CharSequencetext
- the CharSequence to look forProvide an implementation of contains() like Collection.contains to make Strings more polymorphic. This method is not required on JDK 1.5 onwards
self
- a Stringtext
- a String to look forCount the number of occurrences of a sub CharSequence.
self
- a CharSequencetext
- a sub CharSequenceCount the number of occurrences of a substring.
self
- a Stringtext
- a substringReturn a CharSequence with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator.
self
- a CharSequence objectReturn a String with lines (separated by LF, CR/LF, or CR) terminated by the platform specific line separator.
self
- a String objectDrops the given number of chars from the head of this CharSequence if they are available.
def text = "Groovy" assert text.drop( 0 ) == 'Groovy' assert text.drop( 2 ) == 'oovy' assert text.drop( 7 ) == ''
self
- the original CharSequencenum
- the number of characters to drop from this iteratornum
ones,
or else an empty String, if this CharSequence has less than num
characters.Create a suffix of the given CharSequence by dropping as many characters as possible from the front of the original CharSequence such that calling the given closure condition evaluates to true when passed each of the dropped characters.
def text = "Groovy" assert text.dropWhile{ false } == 'Groovy' assert text.dropWhile{ true } == '' assert text.dropWhile{ it < 'Z' } == 'roovy' assert text.dropWhile{ it != 'v' } == 'vy'
self
- the original CharSequencecondition
- the closure that while continuously evaluating to true will cause us to drop elements from
the front of the original CharSequenceIterates through this CharSequence line by line. Each line is passed to the given 1 or 2 arg closure. If a 2 arg closure is found the line count is passed as the second argument.
self
- a CharSequenceclosure
- a closureIterates through this CharSequence line by line. Each line is passed to the given 1 or 2 arg closure. If a 2 arg closure is found the line count is passed as the second argument.
self
- a CharSequencefirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)Iterates through this String line by line. Each line is passed to the given 1 or 2 arg closure. If a 2 arg closure is found the line count is passed as the second argument.
self
- a Stringclosure
- a closureIterates through this String line by line. Each line is passed to the given 1 or 2 arg closure. If a 2 arg closure is found the line count is passed as the second argument.
self
- a StringfirstLine
- the line number value used for the first line (default is 1, set to 0 to start counting from 0)closure
- a closure (arg 1 is line, optional arg 2 is line number)Process each regex group matched substring of the given CharSequence. If the closure parameter takes one argument, an array with all match groups is passed to it. If the closure takes as many arguments as there are match groups, then each parameter will be one match group.
self
- the source CharSequenceregex
- a Regex CharSequenceclosure
- a closure with one parameter or as much parameters as groupsProcess each regex group matched substring of the given pattern. If the closure parameter takes one argument, an array with all match groups is passed to it. If the closure takes as many arguments as there are match groups, then each parameter will be one match group.
self
- the source CharSequencepattern
- a regex Patternclosure
- a closure with one parameter or as much parameters as groupsProcess each regex group matched substring of the given pattern. If the closure parameter takes one argument, an array with all match groups is passed to it. If the closure takes as many arguments as there are match groups, then each parameter will be one match group.
self
- the source stringpattern
- a regex Patternclosure
- a closure with one parameter or as much parameters as groupsProcess each regex group matched substring of the given string. If the closure parameter takes one argument, an array with all match groups is passed to it. If the closure takes as many arguments as there are match groups, then each parameter will be one match group.
self
- the source stringregex
- a Regex stringclosure
- a closure with one parameter or as much parameters as groupsExpands all tabs into spaces with tabStops of size 8.
self
- A CharSequence to expandExpands all tabs into spaces. If the CharSequence has multiple lines, expand each line - restarting tab stops at the start of each line.
self
- A CharSequence to expandtabStop
- The number of spaces a tab representsExpands all tabs into spaces with tabStops of size 8.
self
- A String to expandExpands all tabs into spaces. If the String has multiple lines, expand each line - restarting tab stops at the start of each line.
self
- A String to expandtabStop
- The number of spaces a tab representsExpands all tabs into spaces. Assumes the CharSequence represents a single line of text.
self
- A line to expandtabStop
- The number of spaces a tab representsExpands all tabs into spaces. Assumes the String represents a single line of text.
self
- A line to expandtabStop
- The number of spaces a tab representsFinds the first occurrence of a regular expression CharSequence within a CharSequence.
self
- a CharSequenceregex
- the capturing regexReturns the result of calling a closure with the first occurrence of a regular expression found within a CharSequence. If the regex doesn't match, the closure will not be called and find will return null.
self
- a CharSequenceregex
- the capturing regex CharSequenceclosure
- the closure that will be passed the full match, plus each of the capturing groups (if any)Finds the first occurrence of a compiled regular expression Pattern within a CharSequence.
self
- a CharSequencepattern
- the compiled regex PatternReturns the result of calling a closure with the first occurrence of a regular expression found within a CharSequence. If the regex doesn't match, the closure will not be called and find will return null.
self
- a CharSequencepattern
- the compiled regex Patternclosure
- the closure that will be passed the full match, plus each of the capturing groups (if any)Finds the first occurrence of a compiled regular expression Pattern within a String. If the pattern doesn't match, null will be returned.
For example, if the pattern doesn't match the result is null:
assert null == "New York, NY".find(~/\d{5}/)If it does match, we get the matching string back:
assert "10292" == "New York, NY 10292-0098".find(~/\d{5}/)If we have capture groups in our expression, the groups are ignored and we get back the full match:
assert "10292-0098" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/)If you need to work with capture groups, then use the closure version of this method or use Groovy's matcher operators or use eachMatch.
self
- a Stringpattern
- the compiled regex PatternReturns the result of calling a closure with the first occurrence of a compiled regular expression found within a String. If the regex doesn't match, the closure will not be called and find will return null.
For example, if the pattern doesn't match, the result is null:
assert null == "New York, NY".find(~/\d{5}/) { match -> return "-$match-"}If it does match and we don't have any capture groups in our regex, there is a single parameter on the closure that the match gets passed to:
assert "-10292-" == "New York, NY 10292-0098".find(~/\d{5}/) { match -> return "-$match-"}If we have capture groups in our expression, our closure has one parameter for the match, followed by one for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert match == "10292-0098" assert zip == "10292" assert plusFour == "0098" return zip }If we have capture groups in our expression, and our closure has one parameter, the closure will be passed an array with the first element corresponding to the whole match, followed by an element for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert array[0] == "10292-0098" assert array[1] == "10292" assert array[2] == "0098" return array[1] }If a capture group is optional, and doesn't match, then the corresponding value for that capture group passed to the closure will be null as illustrated here:
assert "2339999" == "adsf 233-9999 adsf".find(~/(\d{3})?-?(\d{3})-(\d{4})/) { match, areaCode, exchange, stationNumber -> assert "233-9999" == match assert null == areaCode assert "233" == exchange assert "9999" == stationNumber return "$exchange$stationNumber" }
self
- a Stringpattern
- the compiled regex Patternclosure
- the closure that will be passed the full match, plus each of the capturing groups (if any)Finds the first occurrence of a regular expression String within a String. If the regex doesn't match, null will be returned.
For example, if the regex doesn't match the result is null:
assert null == "New York, NY".find(/\d{5}/)If it does match, we get the matching string back:
assert "10292" == "New York, NY 10292-0098".find(/\d{5}/)If we have capture groups in our expression, we still get back the full match
assert "10292-0098" == "New York, NY 10292-0098".find(/(\d{5})-?(\d{4})/)
self
- a Stringregex
- the capturing regexReturns the result of calling a closure with the first occurrence of a regular expression found within a String. If the regex doesn't match, the closure will not be called and find will return null.
For example, if the regex doesn't match, the result is null:
assert null == "New York, NY".find(~/\d{5}/) { match -> return "-$match-"}If it does match and we don't have any capture groups in our regex, there is a single parameter on the closure that the match gets passed to:
assert "-10292-" == "New York, NY 10292-0098".find(~/\d{5}/) { match -> return "-$match-"}If we have capture groups in our expression, our closure has one parameter for the match, followed by one for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert match == "10292-0098" assert zip == "10292" assert plusFour == "0098" return zip }If we have capture groups in our expression, and our closure has one parameter, the closure will be passed an array with the first element corresponding to the whole match, followed by an element for each of the capture groups:
assert "10292" == "New York, NY 10292-0098".find(~/(\d{5})-?(\d{4})/) { match, zip, plusFour -> assert array[0] == "10292-0098" assert array[1] == "10292" assert array[2] == "0098" return array[1] }If a capture group is optional, and doesn't match, then the corresponding value for that capture group passed to the closure will be null as illustrated here:
assert "2339999" == "adsf 233-9999 adsf".find(~/(\d{3})?-?(\d{3})-(\d{4})/) { match, areaCode, exchange, stationNumber -> assert "233-9999" == match assert null == areaCode assert "233" == exchange assert "9999" == stationNumber return "$exchange$stationNumber" }
self
- a Stringregex
- the capturing regex stringclosure
- the closure that will be passed the full match, plus each of the capturing groups (if any)Returns a (possibly empty) list of all occurrences of a regular expression (in CharSequence format) found within a CharSequence.
self
- a CharSequenceregex
- the capturing regex CharSequenceFinds all occurrences of a capturing regular expression CharSequence within a CharSequence.
self
- a CharSequenceregex
- the capturing regex CharSequenceclosure
- will be passed the full match plus each of the capturing groups (if any)Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a CharSequence.
self
- a CharSequencepattern
- the compiled regex PatternFinds all occurrences of a compiled regular expression Pattern within a CharSequence.
self
- a CharSequencepattern
- the compiled regex Patternclosure
- will be passed the full match plus each of the capturing groups (if any)Returns a (possibly empty) list of all occurrences of a regular expression (in Pattern format) found within a String.
For example, if the pattern doesn't match, it returns an empty list:
assert [] == "foo".findAll(~/(\w*) Fish/)Any regular expression matches are returned in a list, and all regex capture groupings are ignored, only the full match is returned:
def expected = ["One Fish", "Two Fish", "Red Fish", "Blue Fish"] assert expected == "One Fish, Two Fish, Red Fish, Blue Fish".findAll(~/(\w*) Fish/)
self
- a Stringpattern
- the compiled regex PatternFinds all occurrences of a compiled regular expression Pattern within a String. Any matches are passed to the specified closure. The closure is expected to have the full match in the first parameter. If there are any capture groups, they will be placed in subsequent parameters.
If there are no matches, the closure will not be called, and an empty List will be returned.
For example, if the pattern doesn't match, it returns an empty list:
assert [] == "foo".findAll(~/(\w*) Fish/) { match, firstWord -> return firstWord }Any regular expression matches are passed to the closure, if there are no capture groups, there will be one parameter for the match:
assert ["couldn't", "wouldn't"] == "I could not, would not, with a fox.".findAll(~/.ould/) { match -> "${match}n't"}If there are capture groups, the first parameter will be the match followed by one parameter for each capture group:
def orig = "There's a Wocket in my Pocket" assert ["W > Wocket", "P > Pocket"] == orig.findAll(~/(.)ocket/) { match, firstLetter -> "$firstLetter > $match" }
self
- a Stringpattern
- the compiled regex Patternclosure
- will be passed the full match plus each of the capturing groups (if any)Returns a (possibly empty) list of all occurrences of a regular expression (in String format) found within a String.
For example, if the regex doesn't match, it returns an empty list:
assert [] == "foo".findAll(/(\w*) Fish/)Any regular expression matches are returned in a list, and all regex capture groupings are ignored, only the full match is returned:
def expected = ["One Fish", "Two Fish", "Red Fish", "Blue Fish"] assert expected == "One Fish, Two Fish, Red Fish, Blue Fish".findAll(/(\w*) Fish/)If you need to work with capture groups, then use the closure version of this method or use Groovy's matcher operators or use eachMatch.
self
- a Stringregex
- the capturing regex StringFinds all occurrences of a regular expression string within a String. Any matches are passed to the specified closure. The closure is expected to have the full match in the first parameter. If there are any capture groups, they will be placed in subsequent parameters.
If there are no matches, the closure will not be called, and an empty List will be returned.
For example, if the regex doesn't match, it returns an empty list:
assert [] == "foo".findAll(/(\w*) Fish/) { match, firstWord -> return firstWord }Any regular expression matches are passed to the closure, if there are no capture groups, there will be one parameter for the match:
assert ["couldn't", "wouldn't"] == "I could not, would not, with a fox.".findAll(/.ould/) { match -> "${match}n't"}If there are capture groups, the first parameter will be the match followed by one parameter for each capture group:
def orig = "There's a Wocket in my Pocket" assert ["W > Wocket", "P > Pocket"] == orig.findAll(/(.)ocket/) { match, firstLetter -> "$firstLetter > $match" }
self
- a Stringregex
- the capturing regex Stringclosure
- will be passed the full match plus each of the capturing groups (if any)Select a List of characters from a CharSequence using a Collection to identify the indices to be selected.
self
- a CharSequenceindices
- a Collection of indicesSupport the range subscript operator for CharSequence or StringBuffer with EmptyRange
text
- a CharSequencerange
- an EmptyRangeSupport the subscript operator for CharSequence.
text
- a CharSequenceindex
- the index of the Character to getSupport the range subscript operator for CharSequence or StringBuffer with IntRange
text
- a CharSequencerange
- an IntRangeSupport the range subscript operator for CharSequence
text
- a CharSequencerange
- a RangeSelect a List of values from a Matcher using a Collection to identify the indices to be selected.
self
- a Matcherindices
- a Collection of indicesSupport the subscript operator, e.g. matcher[index], for a regex Matcher.
For an example using no group match,
def p = /ab[d|f]/ def m = "abcabdabeabf" =~ p assert 2 == m.count assert 2 == m.size() // synonym for m.getCount() assert ! m.hasGroup() assert 0 == m.groupCount() def matches = ["abd", "abf"] for (i in 0..<m.count) { assert m[i] == matches[i] }
For an example using group matches,
def p = /(?:ab([c|d|e|f]))/ def m = "abcabdabeabf" =~ p assert 4 == m.count assert m.hasGroup() assert 1 == m.groupCount() def matches = [["abc", "c"], ["abd", "d"], ["abe", "e"], ["abf", "f"]] for (i in 0..<m.count) { assert m[i] == matches[i] }
For another example using group matches,
def m = "abcabdabeabfabxyzabx" =~ /(?:ab([d|x-z]+))/ assert 3 == m.count assert m.hasGroup() assert 1 == m.groupCount() def matches = [["abd", "d"], ["abxyz", "xyz"], ["abx", "x"]] for (i in 0..<m.count) { assert m[i] == matches[i] }
matcher
- a Matcheridx
- an indexSelect a List of characters from a String using a Collection to identify the indices to be selected.
self
- a Stringindices
- a Collection of indicesSupport the range subscript operator for String with EmptyRange
text
- a Stringrange
- an EmptyRangeSupport the subscript operator for String.
text
- a Stringindex
- the index of the Character to getSupport the range subscript operator for String with IntRange
text
- a Stringrange
- an IntRangeSupport the range subscript operator for String
text
- a Stringrange
- a RangeConverts the given CharSequence into an array of characters.
self
- a CharSequenceConverts the given String into an array of characters. Alias for toCharArray.
self
- a StringFind the number of Strings matched to the given Matcher.
matcher
- a MatcherCheck whether a Matcher contains a group or not.
matcher
- a Matchertrue
if matcher contains at least one group.True if a CharSequence only contains whitespace characters.
self
- The CharSequence to check the characters inTrue if a String only contains whitespace characters.
self
- The String to check the characters inDetermine if a CharSequence can be parsed as a BigDecimal.
self
- a CharSequenceDetermine if a String can be parsed into a BigDecimal.
self
- a StringDetermine if a CharSequence can be parsed as a BigInteger.
self
- a CharSequenceDetermine if a String can be parsed into a BigInteger.
self
- a String'Case' implementation for a CharSequence, which simply calls the equivalent method for String.
caseValue
- the case valueswitchValue
- the switch value'Case' implementation for a GString, which simply calls the equivalent method for String.
caseValue
- the case valueswitchValue
- the switch value'Case' implementation for the Pattern class, which allows testing a String against a number of regular expressions. For example:
switch( str ) { case ~/one/ : // the regex 'one' matches the value of str }Note that this returns true for the case where both the pattern and the 'switch' values are
null
.
caseValue
- the case valueswitchValue
- the switch value'Case' implementation for a String, which uses String#equals(Object) in order to allow Strings to be used in switch statements. For example:
switch( str ) { case 'one' : // etc... }Note that this returns
true
for the case where both the
'switch' and 'case' operand is null
.
caseValue
- the case valueswitchValue
- the switch valueDetermine if a CharSequence can be parsed as a Double.
self
- a CharSequenceDetermine if a String can be parsed into a Double.
self
- a StringDetermine if a CharSequence can be parsed as a Float.
self
- a CharSequenceDetermine if a String can be parsed into a Float.
self
- a StringDetermine if a CharSequence can be parsed as an Integer.
self
- a CharSequenceDetermine if a String can be parsed into an Integer.
self
- a StringDetermine if a CharSequence can be parsed as a Long.
self
- a CharSequenceDetermine if a String can be parsed into a Long.
self
- a StringDetermine if a CharSequence can be parsed as a Number. Synonym for 'isBigDecimal()'.
self
- a CharSequenceDetermine if a String can be parsed into a Number. Synonym for 'isBigDecimal()'.
self
- a StringReturns an Iterator which traverses each match.
matcher
- a Matcher objectOverloads the left shift operator to provide an easy way to append multiple objects as string representations to a CharSequence.
self
- a CharSequencevalue
- an ObjectOverloads the left shift operator to provide an easy way to append multiple objects as string representations to a String.
self
- a Stringvalue
- an ObjectOverloads the left shift operator to provide an easy way to append multiple objects as string representations to a StringBuffer.
self
- a StringBuffervalue
- a value to appendOverloads the left shift operator to provide syntactic sugar for appending to a StringBuilder.
self
- a StringBuildervalue
- an ObjectTells whether or not a CharSequence matches the given compiled regular expression Pattern.
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedTells whether or not self matches the given compiled regular expression Pattern.
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedGiven a matcher that matches a string against a pattern, this method returns true when the string matches the pattern or if a longer string, could match the pattern. For example:
def emailPattern = /\w+@\w+\.\w{2,}/ def matcher = "john@doe" =~ emailPattern assert matcher.matchesPartially() matcher = "john@doe.com" =~ emailPattern assert matcher.matchesPartially() matcher = "john@@" =~ emailPattern assert !matcher.matchesPartially()
matcher
- the MatcherRemove a part of a CharSequence by replacing the first occurrence of target within self with '' and returns the result.
self
- a CharSequencetarget
- an object representing the part to removeRemove a part of a String. This replaces the first occurrence of the regex pattern within self with '' and returns the result.
self
- a Stringpattern
- a Pattern representing the part to removeRemove a part of a String. This replaces the first occurrence of target.toString() within self with '' and returns the result.
self
- a Stringtarget
- an object representing the part to removeRepeat a CharSequence a certain number of times.
self
- a CharSequence to be repeatedfactor
- the number of times the CharSequence should be repeatedRepeat a String a certain number of times.
self
- a String to be repeatedfactor
- the number of times the String should be repeatedThis method is called by the ++ operator for the class CharSequence.
self
- a CharSequenceThis method is called by the ++ operator for the class String. It increments the last character in the given string. If the character in the string is Character.MAX_VALUE a Character.MIN_VALUE will be appended. The empty string is incremented to a string consisting of the character Character.MIN_VALUE.
self
- a StringReturn a CharSequence with linefeeds and carriage returns normalized to linefeeds.
self
- a CharSequence objectReturn a String with linefeeds and carriage returns normalized to linefeeds.
self
- a String objectPad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencePad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the left.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for paddingPad a String to a minimum length specified by numberOfChars by adding the space character to the left as many times as needed. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
println 'Numbers:' [1, 10, 100, 1000].each{ println it.toString().padLeft(5) }will produce output like:
Numbers: 1 10 100 1000
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringPad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the left. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
println 'Numbers:' [1, 10, 100, 1000].each{ println it.toString().padLeft(5, '*') } [2, 20, 200, 2000].each{ println it.toString().padLeft(5, '*_') }will produce output like:
Numbers: ****1 ***10 **100 *1000 *_*_2 *_*20 *_200 *2000
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for paddingPad a CharSequence to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting stringPad a CharSequence to a minimum length specified by numberOfChars, adding the supplied padding CharSequence as many times as needed to the right.
self
- a CharSequence objectnumberOfChars
- the total minimum number of characters of the resulting CharSequencepadding
- the characters used for paddingPad a String to a minimum length specified by numberOfChars by adding the space character to the right as many times as needed. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
['A', 'BB', 'CCC', 'DDDD'].each{ println it.padRight(5) + it.size() }will produce output like:
A 1 BB 2 CCC 3 DDDD 4
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringPad a String to a minimum length specified by numberOfChars, adding the supplied padding String as many times as needed to the right. If the String is already the same size or bigger than the target numberOfChars, then the original String is returned. An example:
['A', 'BB', 'CCC', 'DDDD'].each{ println it.padRight(5, '#') + it.size() }will produce output like:
A####1 BB###2 CCC##3 DDDD#4
self
- a String objectnumberOfChars
- the total minimum number of characters of the resulting stringpadding
- the characters used for paddingAppends the String representation of the given operand to this string.
left
- a CharSequencevalue
- any ObjectAppends a String to the string representation of this number.
value
- a Numberright
- a StringAppends the String representation of the given operand to this string.
left
- a Stringvalue
- any ObjectAppends the String representation of the given operand to this string.
left
- a Stringvalue
- any CharSequenceAppends a String to this StringBuffer.
left
- a StringBuffervalue
- a StringThis method is called by the -- operator for the class CharSequence.
self
- a CharSequenceThis method is called by the -- operator for the class String. It decrements the last character in the given string. If the character in the string is Character.MIN_VALUE it will be deleted. The empty string can't be decremented.
self
- a StringSupport the range subscript operator for StringBuffer.
self
- a StringBufferrange
- a Rangevalue
- the object that's toString() will be insertedSupport the range subscript operator for StringBuffer. Index values are treated as characters within the buffer.
self
- a StringBufferrange
- a Rangevalue
- the object that's toString() will be insertedReturn the lines of a CharSequence as a List of CharSequence.
self
- a CharSequence objectReturn the lines of a String as a List of Strings.
self
- a String objectReplaces each substring of this CharSequence that matches the given regular expression with the given replacement.
self
- a CharSequenceregex
- the capturing regexreplacement
- the capturing regexReplaces all occurrences of a captured group by the result of a closure on that text.
self
- a CharSequenceregex
- the capturing regexclosure
- the closure to apply on each captured groupReplaces all substrings of a CharSequence that match the given compiled regular expression with the given replacement.
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the CharSequence of interest is to be matchedreplacement
- the CharSequence to be substituted for the first matchReplaces all occurrences of a captured group by the result of a closure call on that text.
self
- a CharSequencepattern
- the capturing regex Patternclosure
- the closure to apply on each captured groupReplaces all occurrences of a captured group by the result of a closure call on that text.
For examples,
assert "hellO wOrld" == "hello world".replaceAll(~"(o)") { it[0].toUpperCase() } assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll(~"(([fF][oO]{2})[bB]ar)", { it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll(~"(([fF][oO]{2})[bB]ar)", { Object[] it -> it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOO-FOO-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { x, y, z -> z.toUpperCase() }) Here, x is the global string of the matched group y is the first string in the matched group z is the second string in the matched groupNote that unlike String.replaceAll(String regex, String replacement), where the replacement string treats '$' and '\' specially (for group substitution), the result of the closure is converted to a string and that value is used literally for the replacement.
self
- a Stringpattern
- the capturing regex Patternclosure
- the closure to apply on each captured groupReplaces all substrings of a String that match the given compiled regular expression with the given replacement.
Note that backslashes (\) and dollar signs ($) in the replacement string may cause the results to be different than if it were being treated as a literal replacement string; see Matcher.replaceAll. Use Matcher.quoteReplacement to suppress the special meaning of these characters, if desired.
assert "foo".replaceAll('o', 'X') == 'fXX'
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedreplacement
- the string to be substituted for the first matchReplaces all occurrences of a captured group by the result of a closure on that text.
For examples,
assert "hellO wOrld" == "hello world".replaceAll("(o)") { it[0].toUpperCase() } assert "FOOBAR-FOOBAR-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { Object[] it -> it[0].toUpperCase() }) Here, it[0] is the global string of the matched group it[1] is the first string in the matched group it[2] is the second string in the matched group assert "FOO-FOO-" == "foobar-FooBar-".replaceAll("(([fF][oO]{2})[bB]ar)", { x, y, z -> z.toUpperCase() }) Here, x is the global string of the matched group y is the first string in the matched group z is the second string in the matched groupNote that unlike String.replaceAll(String regex, String replacement), where the replacement string treats '$' and '\' specially (for group substitution), the result of the closure is converted to a string and that value is used literally for the replacement.
self
- a Stringregex
- the capturing regexclosure
- the closure to apply on each captured groupReplaces the first substring of this CharSequence that matches the given regular expression with the given replacement.
self
- a CharSequenceregex
- the capturing regexreplacement
- the capturing regexReplaces the first occurrence of a captured group by the result of a closure call on that text.
self
- a CharSequenceregex
- the capturing regexclosure
- the closure to apply on the first captured groupReplaces the first substring of a CharSequence that matches the given compiled regular expression with the given replacement.
self
- the CharSequence that is to be matchedpattern
- the regex Pattern to which the CharSequence of interest is to be matchedreplacement
- the CharSequence to be substituted for the first matchReplaces the first occurrence of a captured group by the result of a closure call on that text.
self
- a CharSequencepattern
- the capturing regex Patternclosure
- the closure to apply on the first captured groupReplaces the first occurrence of a captured group by the result of a closure call on that text.
For example (with some replaceAll variants thrown in for comparison purposes),
assert "hellO world" == "hello world".replaceFirst(~"(o)") { it[0].toUpperCase() } // first match assert "hellO wOrld" == "hello world".replaceAll(~"(o)") { it[0].toUpperCase() } // all matches assert '1-FISH, two fish' == "one fish, two fish".replaceFirst(~/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() } assert '1-FISH, 2-FISH' == "one fish, two fish".replaceAll(~/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() }
self
- a Stringpattern
- the capturing regex Patternclosure
- the closure to apply on the first captured groupReplaces the first substring of a String that matches the given compiled regular expression with the given replacement.
Note that backslashes (\) and dollar signs ($) in the replacement string may cause the results to be different than if it were being treated as a literal replacement string; see Matcher.replaceFirst. Use Matcher.quoteReplacement to suppress the special meaning of these characters, if desired.
assert "foo".replaceFirst('o', 'X') == 'fXo'
self
- the string that is to be matchedpattern
- the regex Pattern to which the string of interest is to be matchedreplacement
- the string to be substituted for the first matchReplaces the first occurrence of a captured group by the result of a closure call on that text.
For example (with some replaceAll variants thrown in for comparison purposes),
assert "hellO world" == "hello world".replaceFirst("(o)") { it[0].toUpperCase() } // first match assert "hellO wOrld" == "hello world".replaceAll("(o)") { it[0].toUpperCase() } // all matches assert '1-FISH, two fish' == "one fish, two fish".replaceFirst(/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() } assert '1-FISH, 2-FISH' == "one fish, two fish".replaceAll(/([a-z]{3})\s([a-z]{4})/) { [one:1, two:2][it[1]] + '-' + it[2].toUpperCase() }
self
- a Stringregex
- the capturing regexclosure
- the closure to apply on the first captured groupCreates a new CharSequence which is the reverse (backwards) of this string
self
- a CharSequenceCreates a new string which is the reverse (backwards) of this string
self
- a StringSet the position of the given Matcher to the given index.
matcher
- a Matcheridx
- the index number Provide the standard Groovy size()
method for CharSequence
.
text
- a CharSequence Provide the standard Groovy size()
method for Matcher
.
self
- a matcher object Provide the standard Groovy size()
method for String
.
text
- a String Provide the standard Groovy size()
method for StringBuffer
.
buffer
- a StringBufferConvenience method to split a CharSequence (with whitespace as delimiter). Similar to tokenize, but returns an Array of CharSequence instead of a List.
self
- the CharSequence to splitConvenience method to split a GString (with whitespace as delimiter).
self
- the GString to splitConvenience method to split a string (with whitespace as delimiter) Like tokenize, but returns an Array of Strings instead of a List
self
- the string to splitIterates through the given CharSequence line by line, splitting each line using the given separator. The list of tokens for each line is then passed to the given closure.
self
- a CharSequenceregex
- the delimiting regular expressionclosure
- a closureIterates through the given CharSequence line by line, splitting each line using the given separator Pattern. The list of tokens for each line is then passed to the given closure.
self
- a CharSequencepattern
- the regular expression Pattern for the delimiterclosure
- a closureIterates through the given String line by line, splitting each line using the given separator Pattern. The list of tokens for each line is then passed to the given closure.
self
- a Stringpattern
- the regular expression Pattern for the delimiterclosure
- a closureIterates through the given String line by line, splitting each line using the given separator. The list of tokens for each line is then passed to the given closure.
self
- a Stringregex
- the delimiting regular expressionclosure
- a closureStrip leading spaces from every line in a CharSequence. The line with the least number of leading spaces determines the number to remove. Lines only containing whitespace are ignored when calculating the number of leading spaces to strip.
self
- The CharSequence to strip the leading spaces fromStrip numChar leading characters from every line in a CharSequence.
self
- The CharSequence to strip the characters fromnumChars
- The number of characters to stripStrip leading spaces from every line in a String. The line with the least number of leading spaces determines the number to remove. Lines only containing whitespace are ignored when calculating the number of leading spaces to strip.
assert ' A\n B\nC' == ' A\n B\n C'.stripIndent()
self
- The String to strip the leading spaces fromStrip numChar leading characters from every line in a String.
assert 'DEF\n456' == '''ABCDEF\n123456'''.stripIndent(3)
self
- The String to strip the characters fromnumChars
- The number of characters to stripStrip leading whitespace/control characters followed by '|' from every line in a CharSequence.
self
- The CharSequence to strip the margin fromStrip leading whitespace/control characters followed by marginChar from every line in a String.
self
- The CharSequence to strip the margin frommarginChar
- Any character that serves as margin delimiterStrip leading whitespace/control characters followed by marginChar from every line in a CharSequence.
self
- The CharSequence to strip the margin frommarginChar
- Any character that serves as margin delimiterStrip leading whitespace/control characters followed by '|' from every line in a String.
assert 'ABC\n123\n456' == '''ABC |123 |456'''.stripMargin()
self
- The String to strip the margin fromStrip leading whitespace/control characters followed by marginChar from every line in a String.
assert 'ABC\n123\n456' == '''ABC *123 *456'''.stripMargin('*')
self
- The String to strip the margin frommarginChar
- Any character that serves as margin delimiterStrip leading whitespace/control characters followed by marginChar from every line in a String.
self
- The String to strip the margin frommarginChar
- Any character that serves as margin delimiter Returns the first num
elements from this CharSequence.
def text = "Groovy" assert text.take( 0 ) == '' assert text.take( 2 ) == 'Gr' assert text.take( 7 ) == 'Groovy'
self
- the original CharSequencenum
- the number of chars to take from this CharSequencenum
chars,
or else the whole CharSequence if it has less then num
elements.Returns the longest prefix of this CharSequence where each element passed to the given closure evaluates to true.
def text = "Groovy" assert text.takeWhile{ it < 'A' } == '' assert text.takeWhile{ it < 'Z' } == 'G' assert text.takeWhile{ it != 'v' } == 'Groo' assert text.takeWhile{ it < 'z' } == 'Groovy'
self
- the original CharSequencecondition
- the closure that must evaluate to true to continue taking elementsParse a CharSequence into a BigDecimal
self
- a CharSequenceParse a String into a BigDecimal
self
- a StringParse a CharSequence into a BigInteger
self
- a CharSequenceParse a String into a BigInteger
self
- a StringConverts the given string into a Boolean object. If the trimmed string is "true", "y" or "1" (ignoring case) then the result is true otherwise it is false.
self
- a StringConverts the given string into a Character object using the first character in the string.
self
- a StringParse a CharSequence into a Double
self
- a CharSequenceParse a String into a Double
self
- a StringParse a CharSequence into a Float
self
- a CharSequenceParse a String into a Float
self
- a StringParse a CharSequence into an Integer
self
- a CharSequenceParse a String into an Integer
self
- a StringConverts the given CharSequence into a List of CharSequence of one character.
self
- a CharSequenceConverts the given String into a List of strings of one character.
self
- a StringParse a CharSequence into a Long
self
- a CharSequenceParse a String into a Long
self
- a StringConverts the given CharSequence into a Set of unique CharSequence of one character.
self
- a CharSequenceConverts the given String into a Set of unique strings of one character.
Example usage:
assert 'groovy'.toSet() == ['v', 'g', 'r', 'o', 'y'] as Set assert "abc".toSet().iterator()[0] instanceof String
self
- a StringParse a CharSequence into a Short
self
- a CharSequenceParse a String into a Short
self
- a StringTokenize a CharSequence (with a whitespace as the delimiter).
self
- a CharSequenceTokenize a CharSequence based on the given character delimiter.
self
- a CharSequencetoken
- the delimiterTokenize a CharSequence based on the given CharSequence delimiter.
self
- a CharSequencetoken
- the delimiterTokenize a String (with a whitespace as the delimiter).
self
- a StringTokenize a String based on the given character delimiter. For example:
char pathSep = ':' assert "/tmp:/usr".tokenize(pathSep) == ["/tmp", "/usr"]
self
- a Stringtoken
- the delimiterTokenize a String based on the given string delimiter.
self
- a Stringtoken
- the delimiterTranslates a string by replacing characters from the sourceSet with characters from replacementSet.
self
- the CharSequence that is to be translatedsourceSet
- the set of characters to translate fromreplacementSet
- the set of replacement charactersTranslates a string by replacing characters from the sourceSet with characters from replacementSet. If the first character from sourceSet appears in the string, it will be replaced with the first character from replacementSet. If the second character from sourceSet appears in the string, it will be replaced with the second character from replacementSet. and so on for all provided replacement characters.
Here is an example which converts the vowels in a word from lower to uppercase:
assert 'hello'.tr('aeiou', 'AEIOU') == 'hEllO'A character range using regex-style syntax can also be used, e.g. here is an example which converts a word from lower to uppercase:
assert 'hello'.tr('a-z', 'A-Z') == 'HELLO'Hyphens at the start or end of sourceSet or replacementSet are treated as normal hyphens and are not considered to be part of a range specification. Similarly, a hyphen immediately after an earlier range is treated as a normal hyphen. So, '-x', 'x-' have no ranges while 'a-c-e' has the range 'a-c' plus the '-' character plus the 'e' character.
Unlike the unix tr command, Groovy's tr command supports reverse ranges, e.g.:
assert 'hello'.tr('z-a', 'Z-A') == 'HELLO'If replacementSet is smaller than sourceSet, then the last character from replacementSet is used as the replacement for all remaining source characters as shown here:
assert 'Hello World!'.tr('a-z', 'A') == 'HAAAA WAAAA!'If sourceSet contains repeated characters, the last specified replacement is used as shown here:
assert 'Hello World!'.tr('lloo', '1234') == 'He224 W4r2d!'The functionality provided by tr can be achieved using regular expressions but tr provides a much more compact notation and efficient implementation for certain scenarios.
self
- the string that is to be translatedsourceSet
- the set of characters to translate fromreplacementSet
- the set of replacement charactersReplaces sequences of whitespaces with tabs using tabStops of size 8.
self
- A CharSequence to unexpandReplaces sequences of whitespaces with tabs.
self
- A CharSequence to unexpandtabStop
- The number of spaces a tab representsReplaces sequences of whitespaces with tabs using tabStops of size 8.
self
- A String to unexpandReplaces sequences of whitespaces with tabs.
self
- A String to unexpandtabStop
- The number of spaces a tab representsReplaces sequences of whitespaces with tabs within a line.
self
- A line to unexpandtabStop
- The number of spaces a tab represents