Jump to content

Welcome to CodeNameJessica

Welcome to CodeNameJessica!

💻 Where tech meets community.

Hello, Guest! 👋
You're just a few clicks away from joining an exclusive space for tech enthusiasts, problem-solvers, and lifelong learners like you.

🔐 Why Join?
By becoming a member of CodeNameJessica, you’ll get access to:
In-depth discussions on Linux, Security, Server Administration, Programming, and more
Exclusive resources, tools, and scripts for IT professionals
A supportive community of like-minded individuals to share ideas, solve problems, and learn together
Project showcases, guides, and tutorials from our members
Personalized profiles and direct messaging to collaborate with other techies

🌐 Sign Up Now and Unlock Full Access!
As a guest, you're seeing just a glimpse of what we offer. Don't miss out on the complete experience! Create a free account today and start exploring everything CodeNameJessica has to offer.

Word Boundaries (Page 10)

(0 reviews)

The \b metacharacter is an anchor, similar to the caret (^) and dollar sign ($). It matches a zero-length position called a word boundary. Word boundaries allow you to perform “whole word” searches in a string using patterns like \bword\b.


What is a Word Boundary?

A word boundary occurs at three possible positions in a string:

  1. Before the first character if it is a word character.

  2. After the last character if it is a word character.

  3. Between two characters where one is a word character and the other is a non-word character.

A word character includes letters, digits, and the underscore ([a-zA-Z0-9_]). Non-word characters are everything else.


Example Usage

The pattern \bword\b matches the word "word" only if it appears as a standalone word in the text.

Regex

String

Matches

\b4\b

"There are 44 sheets"

No

\b4\b

"Sheet number 4 is here"

Yes

Digits are considered word characters, so \b4\b will match a standalone "4" but not when it is part of "44."


Negated Word Boundaries

The \B metacharacter is the negated version of \b. It matches any position that is not a word boundary.

Regex

String

Matches

\Bis\B

"This is a test"

No

\Bis\B

"This island is beautiful"

Yes

\Bis\B would match "is" only if it appears within a word, such as in "island," but not if it appears as a standalone word.


Looking Inside the Regex Engine

Let’s see how the regex \bis\b works on the string "This island is beautiful":

  1. The engine starts with \b at the first character "T." Since \b is zero-width, it checks the position before "T." It matches because "T" is a word character, and the position before it is the start of the string.

  2. The engine then checks the next token, i, which does not match "T," so it moves to the next position.

  3. The engine continues checking until it finds a match at the second "is." The final \b matches before the space after "is," confirming a complete match.


Tcl Word Boundaries

Most regex flavors use \b for word boundaries. However, Tcl uses different syntax:

  • \y matches a word boundary.

  • \Y matches a non-word boundary.

  • \m matches only the start of a word.

  • \M matches only the end of a word.

For example, in Tcl:

  • \mword\M matches "word" as a whole word.

In most flavors, you can achieve the same with \bword\b.


Emulating Tcl Word Boundaries

If your regex flavor supports lookahead and lookbehind, you can emulate Tcl’s \m and \M:

  • (?<!\w)(?=\w): Emulates \m.

  • (?<=\w)(?!\w): Emulates \M.

For flavors without lookbehind, use:

  • \b(?=\w) to emulate \m.

  • \b(?!\w) to emulate \M.


GNU Word Boundaries

GNU extensions to POSIX regular expressions support \b and \B. Additionally, GNU regex introduces:

  • \<: Matches the start of a word (like Tcl’s \m).

  • \>: Matches the end of a word (like Tcl’s \M).

These additional tokens provide flexibility when working with word boundaries in GNU-based tools.


Summary

Word boundaries are crucial for identifying standalone words in text. They prevent partial matches within larger words and ensure more precise regex patterns. Understanding how to use \b, \B, and their equivalents in various regex flavors will help you craft better, more accurate regular expressions.

Table of Contents

  1. Regular Expression Tutorial

  2. Different Regular Expression Engines

  3. Literal Characters

  4. Special Characters

  5. Non-Printable Characters

  6. First Look at How a Regex Engine Works Internally

  7. Character Classes or Character Sets

  8. The Dot Matches (Almost) Any Character

  9. Start of String and End of String Anchors

  10. Word Boundaries

  11. Alternation with the Vertical Bar or Pipe Symbol

  12. Optional Items

  13. Repetition with Star and Plus

  14. Grouping with Round Brackets

  15. Named Capturing Groups

  16. Unicode Regular Expressions

  17. Regex Matching Modes

  18. Possessive Quantifiers

  19. Understanding Atomic Grouping in Regular Expressions

  20. Understanding Lookahead and Lookbehind in Regular Expressions (Lookaround)

  21. Testing Multiple Conditions on the Same Part of a String with Lookaround

  22. Understanding the \G Anchor in Regular Expressions

  23. Using If-Then-Else Conditionals in Regular Expressions

  24. XML Schema Character Classes and Subtraction Explained

  25. Understanding POSIX Bracket Expressions in Regular Expressions

  26. Adding Comments to Regular Expressions: Making Your Regex More Readable

  27. Free-Spacing Mode in Regular Expressions: Improving Readability

0 Comments

Recommended Comments

There are no comments to display.

Guest
Add a comment...

Important Information

Terms of Use Privacy Policy Guidelines We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.