Perl Learning: 8.3. Anchors

Previous Page
Next Page

 

8.3. Anchors

By default, if a pattern doesn't match at the start of the string, it can "float" on down the string trying to match somewhere else. But a number of anchors may be used to hold the pattern at a particular point in a string.

The caret[*] anchor (^) marks the beginning of the string, and the dollar sign ($) marks the end.[] So, the pattern /^fred/ will match fred only at the start of the string; it wouldn't match manfred mann. And /rock$/ will match rock only at the end of the string; it wouldn't match knute rockne.

[*] Yes, you've seen the caret used in another way in patterns. As the first character of a character class, it negates the class. But outside of a character class, it's a metacharacter in a different way, being the start-of-string anchor. There are only so many characters, so you have to use some of them twice.

[] Actually, it matches either the end of the string or at a newline at the end of the string. That's so you can match the end of the string whether it has a trailing newline or not. Most folks don't worry about this distinction much, but once in a while it's important to remember that /^fred$/ will match "fred" or "fred/n" with equal ease.

Sometimes, you'll want to use both of these anchors to ensure that the pattern matches an entire string. A common example is /^/s*$/, which matches a blank line. But this "blank" line may include some whitespace characters, like tabs and spaces, which are invisible. Any line that matches this pattern looks like any other one on paper, so this pattern treats all blank lines equally. Without the anchors, it would match nonblank lines as well.

8.3.1. Word Anchors

Anchors aren't just at the ends of the string. The word-boundary anchor, /b, matches at either end of a word.[] So you can use //bfred/b/ to match the word fred but not frederick, alfred, or manfred mann. This is similar to the feature often called "match whole words only" in a word processor's search command.

[] Some regular expression implementations have one anchor for start-of-word and another for end-of-word, but Perl uses /b for both.

Alas, these aren't words as you and I are likely to think of them; they're those /w-type words made up of ordinary letters, digits, and underscores. The /b anchor matches at the start or end of a group of /w characters.

In Figure 8-1, a gray underline is under each "word," and the arrows show the corresponding places where /b could match. There are always an even number of word boundaries in a given string since there's an end-of-word for every start-of-word.

The "words" are sequences of letters, digits, and underscores. A word in this sense is what's matched by //w+/. There are five words in that sentence: That, s, a, word, and

 

Figure 8-1. Word-boundary matches with /b

 


boundary.[*] The quote marks around word don't change the word boundaries; these words are made of /w characters.

[*] You can see why we wish we could change the definition of "word"; That's should be one word, not two words with an apostrophe in between. Even in text that may be mostly ordinary English, it's normal to find a soupçon of other characters spicing things up.

Each arrow points to the beginning or the end of one of the gray underlines since the word-boundary anchor /b matches only at the beginning or the end of a group of word characters.

The word-boundary anchor is useful to ensure we don't accidentally find cat in delicatessen, dog in boondoggle, or fish in selfishness. Sometimes, you'll want one word-boundary anchor, as when using //bhunt/ to match words like hunt or hunting or hunter, but not shunt, or when using /stone/b/ to match words like sandstone or flintstone but not capstones.

The nonword-boundary anchor is /B; it matches at any point where /b would not match. So, the pattern //bsearch/B/ will match searches, searching, and searched but not search or researching.

Previous Page
Next Page
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值