In this quick tutorial we’ll explore the CharMatcher utility class in Guava.
1. Remove Special Characters from a String
Let’s start by removing all special characters from a String.
In the following example, we remove all characters that aren’t digit or letter using retainFrom():
@Test public void whenRemoveSpecialCharacters_thenRemoved(){ String input = "H*el.lo,}12"; CharMatcher matcher = CharMatcher.JAVA_LETTER_OR_DIGIT; String result = matcher.retainFrom(input); assertEquals("Hello12", result); }
2. Remove non ASCII characters from String
We can also use CharMatcher to remove non ASCII characters from a String as in the following example:
@Test public void whenRemoveNonASCIIChars_thenRemoved() { String input = "あhello₤"; String result = CharMatcher.ASCII.retainFrom(input); assertEquals("hello", result); result = CharMatcher.inRange('0', 'z').retainFrom(input); assertEquals("hello", result); }
3. Validate String
Next – let’s see how to validate a String using CharMatcher.
We can use matchesAllOf() to check if all characters match a condition. And we can make use of matchesNoneOf() to check if a condition doesn’t apply on any of the String characters.
In the following example, we check if our String is lowercase, contains at least one ‘e‘ character and doesn’t contain any digits:
@Test public void whenValidateString_thenValid(){ String input = "hello"; boolean result = CharMatcher.JAVA_LOWER_CASE.matchesAllOf(input); assertTrue(result); result = CharMatcher.is('e').matchesAnyOf(input); assertTrue(result); result = CharMatcher.JAVA_DIGIT.matchesNoneOf(input); assertTrue(result); }
4. Trim String
Now – let’s see how trim a String using CharMatcher.
In the following example, we use trimLeading(), trimTrailing and trimFrom() to trim our String:
@Test public void whenTrimString_thenTrimmed() { String input = "---hello,,,"; String result = CharMatcher.is('-').trimLeadingFrom(input); assertEquals("hello,,,", result); result = CharMatcher.is(',').trimTrailingFrom(input); assertEquals("---hello", result); result = CharMatcher.anyOf("-,").trimFrom(input); assertEquals("hello", result); }
5. Collapse a String
Next – let’s see how to collapse a String using CharMatcher.
In the following example, we use collapseFrom() to replace consecutive spaces with ‘-‘:
@Test public void whenCollapseFromString_thenCollapsed() { String input = " hel lo "; String result = CharMatcher.is(' ').collapseFrom(input, '-'); assertEquals("-hel-lo-", result); result = CharMatcher.is(' ').trimAndCollapseFrom(input, '-'); assertEquals("hel-lo", result); }
6. Replace from String
We can use CharMatcher to replace specific characters from a String as in the following example:
@Test public void whenReplaceFromString_thenReplaced() { String input = "apple-banana."; String result = CharMatcher.anyOf("-.").replaceFrom(input, '!'); assertEquals("apple!banana!", result); result = CharMatcher.is('-').replaceFrom(input, " and "); assertEquals("apple and banana.", result); }
7. Count Character Occurrences
Finally – let’s see how to count the occurrences of characters using CharMatcher.
In the following example, we count the commas and characters between ‘a‘:’h‘:
@Test public void whenCountCharInString_thenCorrect() { String input = "a, c, z, 1, 2"; int result = CharMatcher.is(',').countIn(input); assertEquals(4, result); result = CharMatcher.inRange('a', 'h').countIn(input); assertEquals(2, result); }
8. Conclusion
In this article we illustrated some of the more useful APIs and real-world usage examples of using Guava for Strings.