mirror of
https://github.com/hwchase17/langchain.git
synced 2025-09-18 16:16:33 +00:00
community[patch]: Skip unexpected 404 HTTP Error in Arxiv download (#21042)
### Description: When attempting to download PDF files from arXiv, an unexpected 404 error frequently occurs. This error halts the operation, regardless of whether there are additional documents to process. As a solution, I suggest implementing a mechanism to ignore and communicate this error and continue processing the next document from the list. Proposed Solution: To address the issue of unexpected 404 errors during PDF downloads from arXiv, I propose implementing the following solution: - Error Handling: Implement error handling mechanisms to catch and handle 404 errors gracefully. - Communication: Inform the user or logging system about the occurrence of the 404 error. - Continued Processing: After encountering a 404 error, continue processing the remaining documents from the list without interruption. This solution ensures that the application can handle unexpected errors without terminating the entire operation. It promotes resilience and robustness in the face of intermittent issues encountered during PDF downloads from arXiv. ### Issue: #20909 ### Dependencies: none --------- Co-authored-by: Bagatur <22008038+baskaryan@users.noreply.github.com>
This commit is contained in:
@@ -27,6 +27,7 @@ class ArxivAPIWrapper(BaseModel):
|
||||
Attributes:
|
||||
top_k_results: number of the top-scored document used for the arxiv tool
|
||||
ARXIV_MAX_QUERY_LENGTH: the cut limit on the query used for the arxiv tool.
|
||||
continue_on_failure (bool): If True, continue loading other URLs on failure.
|
||||
load_max_docs: a limit to the number of loaded documents
|
||||
load_all_available_meta:
|
||||
if True: the `metadata` of the loaded Documents contains all available
|
||||
@@ -54,6 +55,7 @@ class ArxivAPIWrapper(BaseModel):
|
||||
arxiv_exceptions: Any # :meta private:
|
||||
top_k_results: int = 3
|
||||
ARXIV_MAX_QUERY_LENGTH: int = 300
|
||||
continue_on_failure: bool = False
|
||||
load_max_docs: int = 100
|
||||
load_all_available_meta: bool = False
|
||||
doc_content_chars_max: Optional[int] = 4000
|
||||
@@ -225,6 +227,12 @@ class ArxivAPIWrapper(BaseModel):
|
||||
except (FileNotFoundError, fitz.fitz.FileDataError) as f_ex:
|
||||
logger.debug(f_ex)
|
||||
continue
|
||||
except Exception as e:
|
||||
if self.continue_on_failure:
|
||||
logger.error(e)
|
||||
continue
|
||||
else:
|
||||
raise e
|
||||
if self.load_all_available_meta:
|
||||
extra_metadata = {
|
||||
"entry_id": result.entry_id,
|
||||
|
Reference in New Issue
Block a user