mirror of
				https://github.com/explosion/spaCy.git
				synced 2025-10-25 05:01:02 +03:00 
			
		
		
		
	Fix remove pattern from matcher (#4454)
* raise specific error when removing a matcher rule that doesn't exist * rephrasing * bugfix in remove matcher + extended unit test
This commit is contained in:
		
							parent
							
								
									2d249a9502
								
							
						
					
					
						commit
						7d1efac4eb
					
				|  | @ -141,7 +141,7 @@ cdef class Matcher: | |||
|         cdef int i = 0 | ||||
|         while i < self.patterns.size(): | ||||
|             pattern_key = get_ent_id(self.patterns.at(i)) | ||||
|             if pattern_key == key: | ||||
|             if pattern_key == norm_key: | ||||
|                 self.patterns.erase(self.patterns.begin()+i) | ||||
|             else: | ||||
|                 i += 1 | ||||
|  |  | |||
|  | @ -3,6 +3,8 @@ from __future__ import unicode_literals | |||
| 
 | ||||
| import pytest | ||||
| import re | ||||
| 
 | ||||
| from spacy.lang.en import English | ||||
| from spacy.matcher import Matcher | ||||
| from spacy.tokens import Doc, Span | ||||
| 
 | ||||
|  | @ -145,16 +147,27 @@ def test_matcher_sets_return_correct_tokens(en_vocab): | |||
|     assert texts == ["zero", "one", "two"] | ||||
| 
 | ||||
| 
 | ||||
| def test_matcher_remove(en_vocab): | ||||
|     matcher = Matcher(en_vocab) | ||||
| def test_matcher_remove(): | ||||
|     nlp = English() | ||||
|     matcher = Matcher(nlp.vocab) | ||||
|     text = "This is a test case." | ||||
| 
 | ||||
|     pattern = [{"ORTH": "test"}, {"OP": "?"}] | ||||
|     assert len(matcher) == 0 | ||||
|     matcher.add("Rule", None, pattern) | ||||
|     assert "Rule" in matcher | ||||
| 
 | ||||
|     # should give two matches | ||||
|     results1 = matcher(nlp(text)) | ||||
|     assert(len(results1) == 2) | ||||
| 
 | ||||
|     # removing once should work | ||||
|     matcher.remove("Rule") | ||||
| 
 | ||||
|     # should not return any maches anymore | ||||
|     results2 = matcher(nlp(text)) | ||||
|     assert (len(results2) == 0) | ||||
| 
 | ||||
|     # removing again should throw an error | ||||
|     with pytest.raises(ValueError): | ||||
|         matcher.remove("Rule") | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user