Skip to content

Instantly share code, notes, and snippets.

@JitendraZaa
Last active December 15, 2023 00:30
Show Gist options
  • Save JitendraZaa/38a626625d1328788d06186ff9151f18 to your computer and use it in GitHub Desktop.
Save JitendraZaa/38a626625d1328788d06186ff9151f18 to your computer and use it in GitHub Desktop.
Talk to PDF File using Langchain, OpenAI, ChromaDB & Python
import os
import sys
import openai
from langchain.chains import ConversationalRetrievalChain, RetrievalQA
from langchain.chat_models import ChatOpenAI
from langchain.document_loaders import DirectoryLoader, TextLoader
from langchain.embeddings import OpenAIEmbeddings
from langchain.indexes import VectorstoreIndexCreator
from langchain.indexes.vectorstore import VectorStoreIndexWrapper
from langchain.llms import OpenAI
from langchain.vectorstores import Chroma
import myconstants
os.environ["OPENAI_API_KEY"] = myconstants.APIKEY
# Enable to save to disk & reuse the model (for repeated queries on the same data)
PERSIST = True
query = None
if len(sys.argv) > 1:
query = sys.argv[1]
if PERSIST and os.path.exists("persist"):
print("Reusing index...\n")
vectorstore = Chroma(persist_directory="persist", embedding_function=OpenAIEmbeddings())
index = VectorStoreIndexWrapper(vectorstore=vectorstore)
else:
#loader = TextLoader("data/data.txt") # Use this line if you only need data.txt
loader = DirectoryLoader("data/")
if PERSIST:
index = VectorstoreIndexCreator(vectorstore_kwargs={"persist_directory":"persist"}).from_loaders([loader])
else:
index = VectorstoreIndexCreator().from_loaders([loader])
chain = ConversationalRetrievalChain.from_llm(
llm=ChatOpenAI(model="gpt-3.5-turbo"),
retriever=index.vectorstore.as_retriever(search_kwargs={"k": 1}),
)
chat_history = []
while True:
if not query:
query = input("Prompt: ")
if query in ['quit', 'q', 'exit']:
sys.exit()
result = chain({"question": query, "chat_history": chat_history})
print(result['answer'])
chat_history.append((query, result['answer']))
query = None
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment