AmmarFahmy
adding all files
105b369
from pathlib import Path
from typing import Union, List, Iterator
from phi.document import Document
from phi.document.reader.docx import DocxReader
from phi.knowledge.base import AssistantKnowledge
class DocxKnowledgeBase(AssistantKnowledge):
path: Union[str, Path]
formats: List[str] = [".doc", ".docx"]
reader: DocxReader = DocxReader()
@property
def document_lists(self) -> Iterator[List[Document]]:
"""Iterate over doc/docx files and yield lists of documents.
Each object yielded by the iterator is a list of documents.
Returns:
Iterator[List[Document]]: Iterator yielding list of documents
"""
_file_path: Path = Path(self.path) if isinstance(self.path, str) else self.path
if _file_path.exists() and _file_path.is_dir():
for _file in _file_path.glob("**/*"):
if _file.suffix in self.formats:
yield self.reader.read(path=_file)
elif _file_path.exists() and _file_path.is_file() and _file_path.suffix in self.formats:
yield self.reader.read(path=_file_path)