Skip to content
Marvin's Toolbox.

Search tools

Type to filter all tools

Regex Tester

Test a regular expression against your own text and see every match highlighted as you type, with capture groups color coded and broken down match by match. Toggle any JavaScript regex flag, read the exact error when a pattern is invalid, and copy all matches as a list.

Everything runs locally in your browser. Your data never leaves your device.

Quick reference

\d \w \sdigit, word character, whitespace
\D \W \Sanything but a digit, word character, whitespace
.any character except a newline
[abc]one of a, b or c
[^abc]any character except a, b or c
[a-z]a character from a to z
a|ba or b
^ $start and end of the text, or of a line with the m flag
\bword boundary
a* a+ a?zero or more, one or more, optional
a{2,4}two to four times
a+?lazy, match as little as possible
(…)capture group
(?<name>…)named capture group
(?:…)group without capturing
(?=…) (?!…)lookahead, positive and negative
(?<=…) (?<!…)lookbehind, positive and negative
\1back reference to group 1
\n \tnewline, tab
\.a literal dot, escape any special character

Next steps

Send this tool's output straight into another tool.

Replace text in two modes: plain find and replace all, or regular expressions with flag controls and capture group references like $1.

Convert text into every case at once: title case in the APA, AP, Chicago, MLA, Bluebook, AMA and NYT styles, sentence case, upper, lower, camelCase, snake_case, kebab-case and more, each with its own copy button.

Count words, characters, sentences, paragraphs, lines and more as you type, with estimated reading and speaking time.

Remove duplicate lines from a list or text, keeping the first occurrence. Optionally ignore case and whitespace, or drop blank lines too.

Compare two texts and see every added, removed and changed line highlighted, side by side or inline, with the changed words marked within each line. Ignore case, whitespace or blank lines, read a summary of how much changed, and export the result as a unified diff.

Paste a UUID to see what it carries: version, variant, and for time-based versions the exact timestamp, clock sequence and node. Also shows the raw bytes, the 128-bit integer and the URN form.

Decode Base64 to text or encode text to Base64. Paste into the top box, read the result below, and flip the direction with one click. Handles Unicode correctly, reads URL-safe Base64, and shows binary payloads as a hex dump you can download.

Convert between scientific notation and full numbers as you type. Reads 1.23e5, 1.23 × 10^5 and plain numbers, shows the value written out, in normalized scientific notation and in engineering notation, and can round to any number of significant digits.

Sort the lines of a text alphabetically, naturally, by length, by numeric value or shuffled. Reverse the order with a switch, and optionally trim lines, drop blank lines and remove duplicates in the same pass.

Convert a color between HEX, RGB, HSL, HSV, HWB, CMYK, OKLCH and OKLAB. Type into any field and the others update as you go, or pick the color visually. Reads CSS color syntax and keeps alpha where the format supports it.

Check two colors against the WCAG contrast rules. Type or pick a text and a background color, read the contrast ratio, see which AA and AAA checks pass, preview real text at the sizes WCAG distinguishes, and get suggested fixes when a check fails.

Create a QR code for text, a link, an email, a phone number, an SMS, Wi-Fi access or a contact card. Set the error correction level, size, margin and colors, then download it as PNG or SVG or copy it straight to the clipboard.

Paste a cron expression and get a plain English explanation, a field by field breakdown and the next times it would run, in your local timezone or UTC. Reads five field crontab syntax, six fields with seconds, names like MON and macros like @daily.

Work out an IPv4 or IPv6 network from an address with a prefix or netmask: network and broadcast addresses, usable host range, subnet mask, wildcard mask and address type. Adjust the prefix with a slider, read the binary breakdown, and split the network into smaller subnets.

Hash text or a file with MD5, SHA-1, SHA-256, SHA-512, SHA-3, BLAKE2, BLAKE3, CRC32 and more, all computed live as you type. Compare against an expected checksum and copy any digest.

Verify a checksum online: drop a file, paste the expected checksum and see instantly whether they match. The hash type is detected from the checksum itself, covering MD5, SHA-1, SHA-256, SHA-512, BLAKE3, CRC-32 and more, and sha256sum lines or whole checksum files can be pasted as-is.

Encode text for use in URLs or decode percent-escaped strings back to readable text. Choose component, full-URL or form encoding, unwrap double-encoded strings, and break a URL into its parts with every query parameter decoded.

Convert Unix timestamps in seconds, milliseconds, microseconds or nanoseconds to readable dates in your local time, UTC or any timezone, and turn any date back into a timestamp. Shows the live current timestamp and relative time.

Escape text into HTML entities or decode entities back to plain text. Choose named or numeric entities, escape only the unsafe characters or everything outside ASCII, and read the result live.

Paste a JSON Web Token to see its header and payload as formatted JSON, with the token color coded so each part maps to its output. Explains the registered claims, shows expiry as readable dates, flags expired tokens and can verify the signature with a secret or public key.

Compress text or a file with gzip, deflate, brotli or Zstandard and see the size before and after, the compression ratio and how long it took. One click tries every method and recommends the smallest result.

Decompress gzip, deflate, brotli or Zstandard data from a file or pasted Base64 and read the result as text or download it. Detects the format from the magic bytes where possible, with a manual override.

Paste anything that looks encoded and this tool works out what was used and undoes it, layer by layer. The whole BaseXX family from Base16 to Base85, binary, URL escapes, HTML entities, ROT13 and gzip, Brotli or Zstandard compression are detected in any combination, and every step of the chain is reported.

Escape or unescape a string for JSON, JavaScript, regex, shell, SQL, CSV, XML and more. Paste text, pick the target format and copy the result, in either direction.

Paste a PEM certificate to see its subject, issuer, validity dates, subject alternative names, key details, fingerprints and extensions in plain view.

Paste a 2FA secret or an otpauth:// link and watch the one-time codes tick live, with a countdown to the next code. Supports the digit counts, periods and algorithms real authenticators use.

Format code in JavaScript, TypeScript, JSON, JSON5, HTML, Vue, CSS, SCSS, LESS, Markdown, YAML, GraphQL, XML and SQL. Pick tabs or spaces, set the indent width, and format the input in place with one click.

Reveal the characters you can't see in a text: zero-width spaces, non-breaking spaces, bidi marks, control characters and CRLF versus LF line endings. Inspect every occurrence and clean them out with a click.

Test a regular expression against your own text and see every match highlighted as you type, with capture groups color coded and broken down match by match. Toggle any JavaScript regex flag, read the exact error when a pattern is invalid, and copy all matches as a list.

About the Regex Tester

This tool runs a JavaScript regular expression against your own test text and shows the result as you type. Every match is highlighted in the text itself, capture groups get their own colors, and a list below breaks each match down with its line, column and every captured value.

It is built for the everyday loop of writing a pattern, checking what it really matches and adjusting it until it does. An invalid pattern reports the exact error from the regex engine instead of failing quietly, and a quick reference of the common tokens sits right under the tool.

What you can do

  • Test a regular expression against sample text and see the matches instantly.
  • Highlight every match and capture group in the text, each in its own color.
  • Inspect numbered and named capture groups match by match.
  • Toggle the JavaScript regex flags g, i, m, s, u and y.
  • See the exact line, column and character index of every match.
  • Extract everything a pattern matches and copy it as a plain list.
  • Debug an invalid regex with the engine's real error message.

How to use the Regex Tester

  1. 1Type your pattern into the Pattern field, without the surrounding slashes.
  2. 2Pick the flags you need. Global is on by default, so every match is found.
  3. 3Paste your test text below. Matches highlight while you type, in the pattern or in the text.
  4. 4Read the match list for positions and captured group values.
  5. 5Copy all matches as a list, or send them on to another tool.

JavaScript regex flavor

Patterns run on the browser's own regex engine, so what matches here is exactly what matches in JavaScript and TypeScript, in RegExp, String.match, String.matchAll and String.replace. That includes named groups like (?<year>\d{4}), lookaheads and lookbehinds, and Unicode property escapes like \p{Letter} when the u flag is on.

Other engines differ in places. PCRE, Python and Go each have their own syntax quirks, so a pattern that works here may need small changes elsewhere. The common building blocks in the quick reference behave the same almost everywhere.

What the flags do

Global (g) finds every match instead of stopping at the first, and is what you want for testing almost always. Ignore case (i) makes letters match both cases. Multiline (m) lets ^ and $ match at the start and end of every line rather than the whole text. Dot all (s) lets . cross newlines. Unicode (u) turns on strict Unicode mode, where emoji count as one character and \u{…} escapes work. Sticky (y) requires each match to start exactly where the previous one ended.

Working with capture groups

Parentheses capture the part of the match they enclose, numbered from 1 in the order they open. A named group (?<name>…) captures under a readable name as well. The tester colors each group's capture in the highlighted text and lists it per match, including groups that did not take part, so you can see exactly which alternative matched.

When a group captures the wrong thing, the colors usually show why at a glance. Once the pattern captures what you want, Find and Replace applies it with $1 style replacements, and the String Escaper escapes a literal string for use inside a pattern.

Decode Base64 to text or encode text to Base64. Paste into the top box, read the result below, and flip the direction with one click. Handles Unicode correctly, reads URL-safe Base64, and shows binary payloads as a hex dump you can download.

Format code in JavaScript, TypeScript, JSON, JSON5, HTML, Vue, CSS, SCSS, LESS, Markdown, YAML, GraphQL, XML and SQL. Pick tabs or spaces, set the indent width, and format the input in place with one click.

Remove duplicate lines from a list or text, keeping the first occurrence. Optionally ignore case and whitespace, or drop blank lines too.

Replace text in two modes: plain find and replace all, or regular expressions with flag controls and capture group references like $1.

Escape text into HTML entities or decode entities back to plain text. Choose named or numeric entities, escape only the unsafe characters or everything outside ASCII, and read the result live.

Reveal the characters you can't see in a text: zero-width spaces, non-breaking spaces, bidi marks, control characters and CRLF versus LF line endings. Inspect every occurrence and clean them out with a click.