Added search for suitable extractor automatically
parent
beaf99e539
commit
86520ae30e
@ -0,0 +1,25 @@
|
||||
from __future__ import annotations
|
||||
|
||||
from typing import Iterable, Optional, TypeVar
|
||||
|
||||
from .generic import ExtractionError, GeneralExtractor
|
||||
|
||||
|
||||
T = TypeVar("T", bound=GeneralExtractor)
|
||||
|
||||
|
||||
def search_suitable_extractor(extractor_list: Iterable[T], uri: str) -> Optional[T]:
|
||||
best_bet: Optional[T] = None
|
||||
for extractor in extractor_list:
|
||||
match = extractor.uri_suitable(uri)
|
||||
if match.accept_immediately:
|
||||
return extractor
|
||||
if match.can_accept and best_bet is None:
|
||||
best_bet = extractor
|
||||
return best_bet
|
||||
|
||||
def expect_suitable_extractor(extractor_list: Iterable[T], uri: str) -> T:
|
||||
extractor = search_suitable_extractor(extractor_list, uri)
|
||||
if extractor is None:
|
||||
raise ExtractionError(f"No suitable extractor found for uri {uri!r}")
|
||||
return extractor
|
Loading…
Reference in New Issue