From 4daba3abdac521e6e304626c5b562eb7a711e823 Mon Sep 17 00:00:00 2001 From: ines Date: Sun, 14 Jan 2018 14:22:13 +0100 Subject: [PATCH] Add regex section to rule-based matching docs (see #1567, #1833) [ci skip] --- .../_rule-based-matching.jade | 48 +++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/website/usage/_linguistic-features/_rule-based-matching.jade b/website/usage/_linguistic-features/_rule-based-matching.jade index 91a452090..82d48e438 100644 --- a/website/usage/_linguistic-features/_rule-based-matching.jade +++ b/website/usage/_linguistic-features/_rule-based-matching.jade @@ -305,6 +305,54 @@ p | A list of #[code (match_id, start, end)] tuples, describing the | matches. A match tuple describes a span #[code doc[start:end]]. ++h(3, "regex") Using regular expressions + +p + | In some cases, only matching tokens and token attributes isn't enough – + | for example, you might want to match different spellings of a word, + | without having to add a new pattern for each spelling. A simple solution + | is to match a regular expression on the #[code Doc]'s #[code text] and + | use the #[+api("doc#char_span") #[code Doc.char_span]] method to + | create a #[code Span] from the character indices of the match: + ++code. + import spacy + import re + + nlp = spacy.load('en') + doc = nlp(u'The spelling is "definitely", not "definately" or "deffinitely".') + + DEFINITELY_PATTERN = re.compile(r'deff?in[ia]tely') + + for match in re.finditer(DEFINITELY_PATTERN, doc.text): + start, end = match.span() # get matched indices + span = doc.char_span(start, end) # create Span from indices + +p + | You can also use the regular expression with spaCy's #[code Matcher] by + | converting it to a token flag. To ensure efficiency, the + | #[code Matcher] can only access the C-level data. This means that it can + | either use built-in token attributes or #[strong binary flags]. + | #[+api("vocab#add_flag") #[code Vocab.add_flag]] returns a flag ID which + | you can use as a key of a token match pattern. Tokens that match the + | regular expression will return #[code True] for the #[code IS_DEFINITELY] + | flag. + ++code. + IS_DEFINITELY = nlp.vocab.add_flag(re.compile(r'deff?in[ia]tely').match) + + matcher = Matcher(nlp.vocab) + matcher.add('DEFINITELY', None, [{IS_DEFINITELY: True}]) + +p + | Providing the regular expressions as binary flags also lets you use them + | in combination with other token patterns – for example, to match the + | word "definitely" in various spellings, followed by a case-insensitive + | "not" and and adjective: + ++code. + [{IS_DEFINITELY: True}, {'LOWER': 'not'}, {'POS': 'ADJ'}] + +h(3, "example1") Example: Using linguistic annotations p