Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/erabossid/use-of-regex

Understanding Use of Regex
https://github.com/erabossid/use-of-regex

javascript regex

Last synced: about 1 month ago
JSON representation

Understanding Use of Regex

Awesome Lists containing this project

README

        

# Use of Regex
Understanding use of regex methods.

1. **[Test method - Regex.test(String)](#test-method)**
* [Plain search (Case sensitive / insensitive)](#plain-search-with-test-method)
* [Conditional search with Or `|` operator](#conditional-search-with-or--operator-with-test-method)
2. **[Match method - String.match(regex)](#match-method)**
* [Return single word with .match() method](#return-single-word-with-match-method)
* [Get all matched words with .match() method](#retrun-all-words-with-match-method)
* [Get all matched words with .match() method ignoring case](#using-g-and-i-flag-together)
* [Match all words with wildcard dot](#match-with-wildcard-dot)
* [Match a single character from multiple options](#match-a-single-character-from-multiple-options)
* [Match a single character from a wide range of characters options](#match-a-single-character-from-a-wide-range-of-characters-options)
* [Match with negated character set ("Do not match")](#match-with-negated-character-set)
* [Match repeated characters](#match-repeated-characters)

## .test() method
Test method returns true/false.
In this method Content of String to pass inside the test().
`Regex.test("Content of String")`

### Plain search with .test() method
* Regex with case sensitive and find a match with a whole word.

```javascript
let myText = "Yes it is";
let myRegex = /Yes/;
let result = myRegex.test(myText);
//true

let anotherRegex = /yes/;
let anotherResult = myRegex.test(anotherRegex);
// false
```
* Regex with case insensitive and find a match with a whole word
* To make it add an `i` at the end of regex. Here `i` is 'ignore case'.

```javascript
let myText = "Yes it is";
let anotherRegex = /yes/i;
let anotherResult = anotherRegex.test(myText);
//true
```

### Conditional search with 'Or' `|` operator with .test() method
Here regex will return true if any of the given word matches

```javascript
let myText = "Yes, it is okay";
let myRegex = /yes|no|okay/;
let result = myRegex.test(myText);
// true . for matching one of the items 'okay'

```

## .match() method
In this method regex to pass inside the match(). It returns the word searching for if matched (full or partial from the begining), otherwise null

`"String".match(/regexHere/)`
### Return single word with .match() method
```javascript
let myText = "Yes it is";
let myRegex = /Yes/;
let result = myText.match(myRegex)
// returns "Yes"

```
### Return all words with .match() method
Just add `g` flag at the end of the regex. It will return all the matched words in an array.

```javascript
let myText = "Yes it is. Yes, it works";
let myRegex = /Yes/g;
let result = myText.match(myRegex);
// returns ["Yes", "Yes"]
```

### Using `g` and `i` flag together
This will search for multiple match (global) and case insensitive (ignoreCase).

Just add `gi` at the end of the regex.

```javascript
let myText = "Yes, it is, yes, it works";
let myRegex = /Yes/gi;
let result = myText.match(myRegex);
// returns ["Yes", "yes"]
```
### Match with wildcard dot
Using a wildcard dot in regex you can find all the matched word through a pattern.

See these words- dot, don, doc, document, doll, docker...

All are started with common `do` and you can find all the words with a wildcard dot included after `do`

If you add one dot `.` it will continue to one character after the regex word, like `/do./` will match first two chars and will take additional unknown one char,

if you add two dots `..` it will match the first two chars for `do` and continue unknow more two chars for two dots `..` and so on.

```javascript
let myText = "dot, lot, doc, pot, docker";
let myRegex = /do./gi;
// since we need to search for the whole documents we added a `g` tag and then we wanted to match any case with `i` tag
let result = myText.match(myRegex);
// returns ["dot", "doc", "doc"]
// for the word docker it finds `do` then takes one more char for one dot `.` so it takes `doc` from docker
```

### Match a single character from multiple options
This type of regex will find words with a fixed begining and a fixed end character

but with scopes to select the middle characters from multiple options

The following regex starts to match a word started with `d`,

then searches for the second character from `[ou]` either `o` or `u` options,

then finds upto the third character `c`. We also have used `gi` tags to match it global and of any case.

So, it will first match `doc`, then `duc` from duck,

then it will skip for december because first char is ok but second char not matched as `o` or `u`,

then moves to dot and it matched first 2 chars but not the third one `c`.

Finally it will return `doc` and `duc`

```javascript
let myText = "doc, duck, december, dot";
let myRegex = /d[ou]c/gi;
let searchResult = myText.match(myRegex)
//returns ["doc", "duc"]
```
As you see, the characters inside the array `[]` in regex comes with select options, we also can use multiple options at each stage.

```javascript
let myText = "doc, duck, december, dot";
let myRegex = /d[ou][ct]/gi;
let searchResult = myText.match(myRegex)
// returns ["doc", "duc", "dot"]
```

Here we have make options also for the 3rd charatcer `[ct]`.

That means either it will be `c` or `t`. That finds also `dot` for this case.

### Match a single character from a wide range of characters options
In the above we have seen that the characters in array `[ou]` system matches with either `o` or `u`, only 2 options. We can increase it to more like `[abcdefgh]` and so on. But, if we could avoid much typing and save time by writing it with a dash between first and last chars if they are comes serially. Like `[a-h]`, it means it will find and match any one character from `a to h`, and `[a-z]` means from a to z any character. So, `[A-Z]` : A to Z.

```javascript
let myText = "doc, duck, december, dot";
let myRegex = /d[a-u]c/gi;
let searchResult = myText.match(myRegex)
// returns ["doc", "duc", "dec"]
```

### Match with numbers
Like above, place the range of number to select one for each position. The following code will first match for `2` then look for a single number from 0 to 5, and then look for another single number from options 3 to 9. Additionally we have used `g` tag for matching from all the contents.

```javascript
let myText = "202, 205, 206, 210";
let myRegex = /2[0-5][3-9]/g;
let searchResult = myText.match(myRegex)
// return ["205", "206"]
```
Also
```javascript
let myText = "a2b02, a2b05, A2i6, k2b10";
let myRegex = /a[0-5][a-j]/gi;
let searchResult = myText.match(myRegex)
// returns [ 'a2b', 'a2b', 'A2i' ]
```

### Match with negated character set
This type of matching with `^` at the begining of regex means 'do not match' these characters.

When you use this regex, it will search and match all the characters except those given in regex.

Here we are searcing any word starting with `d` and we are saying not to match the second character if it's `o` or `i`

So, it returns only `da`, `de` and `du`. And it will skip `di` and `do`.

```javascript
let myText = "Da de di do du`";
let myRegex = /d[^oi]/gi;
let result = myText.match(myRegex);
//returns ["da", "de", "du"]
```

### Match repeated characters
Repeated characters are matched with a `+` sign after the character which is supposed repeated in a word. Here this regex with `l+` will find `ll` from each match

```javascript
let myText = "ball, committee, tallll";
let myRegex = /l+/gi;
let searchResult = myText.match(myRegex)
// returns ["ll", "llll"]
```

### Match one or more times with asterisk `*`
Asterisk sign in regex matches a character one or more times. The following regex will frist look for `a` with a single or many `l`. Here the asteris sing is with the `l` so it will match for one or more times.

```javascript
let myText = "ball, committee, tallll";
let myRegex = /al*/gi;
let searchResult = myText.match(myRegex)
// returns ["all", "allll"]
```