Gebruikershulpmiddelen

Site-hulpmiddelen


tavily

Verschillen

Dit geeft de verschillen weer tussen de geselecteerde revisie en de huidige revisie van de pagina.

Link naar deze vergelijking

Beide kanten vorige revisieVorige revisie
Volgende revisie
Vorige revisie
tavily [2024/10/02 15:07] – [Links] a3dijketavily [2024/10/13 22:26] (huidige) – [Tavily doorzoekt opgegeven websites] a3dijke
Regel 31: Regel 31:
 ---- ----
  
-===== Voorbeelde gebruik Tavily =====+===== Voorbeeld gebruik Tavily ===== 
 +Hieronder een Python Class met 4 verschillende manieren om Tavily search te gebruiken in Python. Tavily is niet gratis maar er is wel een gratis account waarbij je 1000 verzoeken per maand kunt doen. Dit zou genoeg moeten zijn om te testen. Je hebt een Tavily Api-key nodig: 
 + 
 +[[https://app.tavily.com/home|Maak hier je API-Key aan]] 
 + 
 +Installeer Tavily voor Python //(De integratie leeft in het langchain-community pakket. Maar we moeten ook het tavily-python pakket installeren.)// 
 + 
 +<code>pip install langchain-community</code> 
 +<code>pip install tavily-python</code> 
 + 
 +🔸 Boven iedere functie //(methode)// is in het commentaar te vinden waar de bron te vinden is //(URL)// met meer informatie over de gebruikte methode\\ 
 +🔸 De "tavilyKaal" methode is de basis methode om Tavily te gebruiken in Python zonder toeters en bellen\\ 
 +🔸 De "tavilyLangChainNoChain" methode gebruikt Tavilt in de vorm van een retriever zonder daar verder iets mee te doen\\ 
 +🔸 De "tavilyLangChainWithChain" methode is hetzelfde als de "tavilyLangChainNoChain" maar in een chain en deze methode genereerd een antwoord met behulp van een LLM\\ 
 +🔸 De "tavilyLangChainNoChain" methode steld Tavily als Tool in. Dit is de basis versie welke nog verder uitgewerkt [[https://python.langchain.com/docs/integrations/tools/tavily_search/|is/wordt op deze pagina]] 
 + 
 +💡 **Note:** bij zowel de "TavilySearchAPIRetriever" als bij de "TavilySearchResults" methode kunnen URL's worden opgegeven die doorzocht dienen te worden d.m.v. de "include_domains" parameter
  
 <code>from tavily import TavilyClient <code>from tavily import TavilyClient
Regel 106: Regel 122:
          
  
-    # WRKERS ========================================================+    # WERKERS ========================================================
     def format_docs(self, docs):     def format_docs(self, docs):
         return "\n\n".join(doc.page_content for doc in docs)</code>         return "\n\n".join(doc.page_content for doc in docs)</code>
Regel 113: Regel 129:
 ---- ----
  
 +===== ✨ Tavily doorzoekt opgegeven websites =====
 +<code>from langchain_community.retrievers import TavilySearchAPIRetriever
 +from langchain_core.output_parsers import StrOutputParser
 +from langchain_core.prompts import ChatPromptTemplate
 +from langchain_core.runnables import RunnablePassthrough
 +from langchain_openai import ChatOpenAI
 +import os
 +import streamlit as st
 +import requests  # nodig voor foutafhandeling
 +
 +
 +class Test_2:
 +    def __init__(self):
 +        os.environ["TAVILY_API_KEY"] = st.secrets["TAVILY_API_KEY"]
 +
 +    # https://python.langchain.com/docs/integrations/retrievers/tavily/
 +    def tavilyLangChainWithChain(self, vraag):
 +        try:
 +            retriever = TavilySearchAPIRetriever(
 +                k=3,
 +                include_domains=[
 +                    "kwaliteitsysteem.nl/kennisbank",
 +                    "catcollectief.nl",
 +                    "catvergoedbaar.nl",
 +                    "kwaliteitstherapeuten.nl",
 +                    "batverzekeringen.nl",
 +                    "gatgeschillen.nl",
 +                    "gatregisteropleidingen.nl/",
 +                ],
 +            )
 +            prompt = ChatPromptTemplate.from_template(
 +                """Beantwoord de vraag alleen op basis van de gegeven context.
 +
 +                Context: {context}
 +
 +                Question: {question}"""
 +            )
 +            llm = ChatOpenAI(model="gpt-4o-mini")
 +
 +            chain = (
 +                {"context": retriever | self.format_docs, "question": RunnablePassthrough()}
 +                | prompt
 +                | llm
 +                | StrOutputParser()
 +            )
 +            antw = chain.invoke(vraag)
 +            return antw
 +
 +
 +        except requests.exceptions.HTTPError as e:
 +            print(f"Er is een HTTPError opgetreden: {e}")
 +            return "Er is een fout opgetreden: Invoer moet minimaal uit twee woorden bestaan!"
 +        
 +
 +    # WERKER ========================================================
 +    def format_docs(self, docs):
 +        return "\n\n".join(doc.page_content for doc in docs)</code>
 +
 +
 +----
  
  
  
  
tavily.1727874474.txt.gz · Laatst gewijzigd: 2024/10/02 15:07 door a3dijke