String Handling with Apache Commons' StringUtils Class in Java
Last Updated :
24 Apr, 2025
The Apache Commons Lang library is a popular third-party library for working with Strings in Java, and the StringUtils class is a key part of this library. StringUtils is a utility class that provides a wide range of String manipulation methods that are not available in the standard Java String class.
Key Features of The StringUtils Class
- Null-safe methods: Many of the methods in the StringUtils class are designed to handle null Strings gracefully, rather than throwing NullPointerExceptions. For example, the isBlank() method checks whether a String is null or contains only whitespace characters.
- Methods for manipulating Strings: The StringUtils class provides a range of methods for manipulating Strings, such as trim() to remove leading and trailing whitespace, and substringBefore() and substringAfter() to extract substrings.
- Methods for comparing Strings: The StringUtils class provides methods for comparing Strings, such as equals() and equalsIgnoreCase(), that handle null Strings and avoid NullPointerExceptions.
- Methods for formatting Strings: The StringUtils class provides methods for formatting Strings, such as join() to join an array of Strings into a single String with a separator.
- Methods for handling cases: The StringUtils class provides methods for changing the case of Strings, such as capitalize() to capitalize the first letter of a String, and swapCase() to swap the case of the characters in a String.
- Methods for searching Strings: The StringUtils class provides methods for searching Strings, such as contains() to check whether a String contains a given substring, and indexOf() to find the index of a given substring.
- Methods for manipulating whitespace: The StringUtils class provides methods for manipulating whitespace in Strings, such as normalizeSpace() to convert multiple whitespace characters to a single space, and replaceEach() to replace multiple whitespace characters with a single character.
- Methods for working with characters: The StringUtils class provides methods for working with individual characters in Strings, such as countMatches() to count the number of occurrences of a given character or substring, and remove() to remove a specific character or substring from a String.
- Methods for formatting numbers: The StringUtils class provides methods for formatting numbers as Strings, such as leftPad() and rightPad() to pad a number with leading or trailing zeros or spaces.
- Methods for handling line breaks: The StringUtils class provides methods for handling line breaks in Strings, such as replaceEach() to replace multiple lines breaks with a single line break, and split() to split a String into an array of Strings based on line breaks.
Getting Started with Apache Commons for Maven and Gradle involves the following steps:
For Maven:
Add the Apache Commons Lang dependency to your pom.xml file
XML
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.12.0</version>
</dependency>
Run a Maven build to download the dependency and add it to your project's classpath. Import the StringUtils class in your Java code.
import org.apache.commons.lang3.StringUtils;
Use the StringUtils class in your Java code, as described in the previous answer.
For Gradle:
Add the Apache Commons Lang dependency to your build.gradle file:
dependencies {
implementation 'org.apache.commons:commons-lang3:3.12.0'
}
Run a Gradle build to download the dependency and add it to your project's classpath. Import the StringUtils class in your Java code:
import org.apache.commons.lang3.StringUtils;
Use the StringUtils class in your Java code, as described in the previous answer.
StringUtils Class Available utility Methods
A list of some of the methods available in the StringUtils class of Apache Commons Lang, along with a brief explanation of what each method does:
- isBlank(String str): This method checks if a String is null, empty, or contains only whitespace characters. It returns true if the String is blank, and false otherwise.
- join(Object[] array, String separator): This method joins an array of Objects into a single String, with each element separated by the specified separator. It returns the joined String.
- capitalize(String str): This method capitalizes the first letter of a String and returns the modified String.
- remove(String str, char remove): This method removes all occurrences of a specified character from a String and returns the modified String.
- reverse(String str): This method reverses the order of characters in a String and returns the reversed String.
- substringBefore(String str, String separator): This method returns the substring of a String before the first occurrence of a specified separator. If the separator is not found in the String, the entire String is returned.
- substringAfter(String str, String separator): This method returns the substring of a String after the first occurrence of a specified separator. If the separator is not found in the String, an empty String is returned.
- substringBetween(String str, String open, String close): This method returns the substring of a String between two specified markers. If either marker is not found in the String, null is returned.
- countMatches(String str, String sub): This method counts the number of occurrences of a specified substring within a String and returns the count as an integer.
- isNumeric(String str): This method checks if a String contains only numeric characters (0-9) and optionally a minus sign at the beginning. It returns true if the String is numeric, and false otherwise.
Examples
Below Are the Programs that demonstrate StringUtility class Methods.
Example 1:
Java
import org.apache.commons.lang3.StringUtils;
public class StringUtilsExample {
public static void main(String[] args) {
String str = " hello world ";
// isEmpty() example
boolean empty = StringUtils.isEmpty(str);
System.out.println("Is the string empty? " + empty);
// isBlank() example
boolean blank = StringUtils.isBlank(str);
System.out.println("Is the string blank? " + blank);
// trim() example
String trimmed = StringUtils.trim(str);
System.out.println("The trimmed string is: " + trimmed);
// substring() example
String substring = StringUtils.substring(str, 2, 7);
System.out.println("The substring is: " + substring);
// replace() example
String replaced = StringUtils.replace(str, "world", "Java");
System.out.println("The replaced string is: " + replaced);
// split() example
String[] words = StringUtils.split(str);
System.out.println("The words in the string are:");
for (String word : words) {
System.out.println(word);
}
// join() example
String[] fruits = {"apple", "banana", "orange"};
String joined = StringUtils.join(fruits, ", ");
System.out.println("The joined string is: " + joined);
// capitalize() example
String capitalized = StringUtils.capitalize(str);
System.out.println("The capitalized string is: " + capitalized);
// equalsIgnoreCase() example
boolean equal = StringUtils.equalsIgnoreCase(str, " Hello World ");
System.out.println("Are the strings equal? " + equal);
}
}
Output:
Is the string empty? false
Is the string blank? false
The trimmed string is: hello world
The substring is: llo w
The replaced string is: hello Java
The words in the string are:
hello
world
The joined string is: apple, banana, orange
The capitalized string is: Hello world
Are the strings equal? true
Note: You'll need to have the Apache Commons Lang library added to your project's classpath in order for this program to compile and run successfully.Â
Example 2:
Java
import org.apache.commons.lang3.StringUtils;
public class StringUtilsExample {
public static void main(String[] args) {
String str1 = "Hello";
String str2 = "World";
// concatenate two strings
String result1 = StringUtils.join(new String[]{str1, str2}, " ");
System.out.println("Result 1: " + result1);
// repeat a string
String result2 = StringUtils.repeat(str1, 3);
System.out.println("Result 2: " + result2);
// capitalize first letter
String result3 = StringUtils.capitalize(str1);
System.out.println("Result 3: " + result3);
// swap case
String result4 = StringUtils.swapCase(str2);
System.out.println("Result 4: " + result4);
// count matches
int result5 = StringUtils.countMatches(result1, "l");
System.out.println("Result 5: " + result5);
}
}
Output:
Result 1: Hello World
Result 2: HelloHelloHello
Result 3: Hello
Result 4: wORLD
Result 5: 3
Explanation:
- isNullOrEmpty(String str) - This method takes a string as input and checks if the string is null or empty. If the string is null or empty, it returns true, otherwise, it returns false.
- reverse(String str) - This method takes a string as input and reverses the string. It uses a StringBuilder to append each character of the string in reverse order. It then returns the reversed string.
- countOccurrences(String str, String sub) - This method takes two strings as input - a string and a substring. It then counts the number of occurrences of the substring in the string and returns the count.
- All the methods are static, so they can be accessed without creating an object of the StringUtils class. The methods are useful in different scenarios such as checking if a string is empty, reversing a string, or counting the number of occurrences of a substring in a string.
Note: You'll need to have the Apache Commons Lang library added to your project's classpath in order for this program to compile and run successfully.
Some Additional Insights on StringUtils class in Java
- The StringUtils class provides a number of convenient methods for working with Strings, which can save you time and simplify your code. For example, instead of writing your own method to check if a String is empty or null, you can use the isEmpty() method from the StringUtils class.
- Many of the methods in the StringUtils class have equivalent methods in the standard String class in Java. However, the StringUtils versions often have additional functionality, such as handling null inputs gracefully or ignoring cases when comparing strings.
- The StringUtils class is part of the Apache Commons Lang library, which provides many other useful utility classes for working with Java code. If you find yourself using the StringUtils class frequently, you might want to explore some of the other classes in this library to see if they can help you simplify your code further.
- When using the StringUtils class, be aware that some of the methods can throw a NullPointerException if you pass in a null value. To avoid this, you can either check for null inputs explicitly before calling a StringUtils method or use the StringUtils.defaultString() method to convert null inputs to empty strings.
- When using the split() method in the StringUtils class, be aware that it uses whitespace as the default delimiter if no delimiter is specified. If you want to split on a different character or sequence of characters, you'll need to pass that in as a parameter to the split() method.
Overall, the StringUtils class is a powerful and convenient tool for working with Strings in Java. By learning about the different methods it provides and how to use them effectively, you can simplify your code and save time in your Java programming projects.
Similar Reads
StringWriter write(String, int, int) method in Java with Examples
The write(String, int, int) method of StringWriter Class in Java is used to write a specified portion of the specified String on the stream. This String is taken as a parameter. The starting index and length of String to be written are also taken as parameters. Syntax: public void write(String strin
2 min read
StringBuilder setLength() in Java with Examples
The setLength(int newLength) method of StringBuilder is used to set the length of the character sequence equal to newLength.For every index k greater than 0 and less than newLength. If the newLength passed as argument is less than the old length, the old length is changed to the newLength.If the new
2 min read
Java StringUtils.isNoneBlank() Method with Examples
The StringUtils.isNoneBlank() is a method provided by the Apache Commons Lang library for string manipulation in Java. It is used to check if any of the given strings are not blank or empty. The StringUtils.isNoneBlank() function is part of the Apache Commons Lang library, which provides utility met
3 min read
String toString() Method in java with Examples
String toString() is the built-in method of java.lang which return itself a string. So here no actual conversion is performed. Since toString() method simply returns the current string without any changes, there is no need to call the string explicitly, it is usually called implicitly. Syntax : publ
1 min read
StringBuilder appendCodePoint() method in Java with Examples
The appendCodePoint(int codePoint) method of StringBuilder class is the inbuilt method used to append the string representation of the codePoint argument to this sequence. The argument is appended to this StringBuilder content and length of the object is increased by Character.charCount(codePoint).
2 min read
Searching For Characters and Substring in a String in Java
Efficient String manipulation is very important in Java programming especially when working with text-based data. In this article, we will explore essential methods like indexOf(), contains(), and startsWith() to search characters and substrings within strings in Java.Searching for a Character in a
5 min read
How to Convert a String to an int in Java?
In Java, converting a String to an int is done using methods from the Integer class. The methods used for this conversion are Integer.parseInt() and Integer.valueOf(). Example:The Integer.parseInt() is a commonly used method to convert a string to an integer in Java. This method converts a numeric s
1 min read
Class toString() method in Java with Examples
The toString() method of java.lang.Class class is used to convert the instance of this Class to a string representation. This method returns the formed string representation. Syntax: public String toString() Parameter: This method does not accept any parameter. Return Value: This method returns the
1 min read
StringBuilder length() in Java with Examples
The length() method of StringBuilder class returns the number of character the StringBuilder object contains. The length of the sequence of characters currently represented by this StringBuilder object is returned by this method. Syntax: public int length() Return Value: This method returns length o
2 min read
StringWriter getClass() method in Java with Examples
The getClass() method of StringWriter Class in Java is used to get the parent Class of this StringWriter instance. This method does not accepts any parameter and returns the required Class details. Syntax: public final Class String getClass() Parameters: This method accepts does not accepts any para
2 min read