internet_ml/internet_ml/NLP/no_context/QA.py

45 lines
1.1 KiB
Python

from typing import Any, List, Tuple
import logging
import os
import sys
from pathlib import Path
import dotenv
from transformers import pipeline
dotenv.load_dotenv()
logging.basicConfig(
filename="QA.log",
filemode="w",
level=logging.INFO,
format="%(name)s - %(levelname)s - %(message)s",
)
sys.path.append(str(Path(__file__).parent.parent.parent) + "/tools/NLP/data")
sys.path.append(str(Path(__file__).parent.parent.parent) + "/utils")
import config
import internet
def answer(query: str) -> tuple[Any, list[str]]:
QA_MODEL: Any = pipeline("question-answering")
GOOGLE_SEARCH_API_KEY = str(os.environ["INTERNET_ML_GOOGLE_API"])
GOOGLE_SEARCH_ENGINE_ID = str(os.environ["INTERNET_ML_GOOGLE_SEARCH_ENGINE_ID"])
results: tuple[list[str], list[str]] = internet.Google(
query, GOOGLE_SEARCH_API_KEY, GOOGLE_SEARCH_ENGINE_ID
).google()
answer: tuple[Any, list[str]] = (
QA_MODEL(question=query, context=str(results[0])),
results[1],
)
if config.CONF_DEBUG:
logging.info(f"Answer: {answer}")
return answer
# print(answer("Who is the author of TinTin?"))
# def custom_answer