From 2667ddc6867421842fe027f1946644f452de8eb3 Mon Sep 17 00:00:00 2001 From: os1ma <39944763+os1ma@users.noreply.github.com> Date: Wed, 12 Jul 2023 11:05:14 +0900 Subject: [PATCH] Fix `make docs_build` and related scripts (#7276) **Description: a description of the change** Fixed `make docs_build` and related scripts which caused errors. There are several changes. First, I made the build of the documentation and the API Reference into two separate commands. This is because it takes less time to build. The commands for documents are `make docs_build`, `make docs_clean`, and `make docs_linkcheck`. The commands for API Reference are `make api_docs_build`, `api_docs_clean`, and `api_docs_linkcheck`. It looked like `docs/.local_build.sh` could be used to build the documentation, so I used that. Since `.local_build.sh` was also building API Rerefence internally, I removed that process. `.local_build.sh` also added some Bash options to stop in error or so. Futher more added `cd "${SCRIPT_DIR}"` at the beginning so that the script will work no matter which directory it is executed in. `docs/api_reference/api_reference.rst` is removed, because which is generated by `docs/api_reference/create_api_rst.py`, and added it to .gitignore. Finally, the description of CONTRIBUTING.md was modified. **Issue: the issue # it fixes (if applicable)** https://github.com/hwchase17/langchain/issues/6413 **Dependencies: any dependencies required for this change** `nbdoc` was missing in group docs so it was added. I installed it with the `poetry add --group docs nbdoc` command. I am concerned if any modifications are needed to poetry.lock. I would greatly appreciate it if you could pay close attention to this file during the review. **Tag maintainer** - General / Misc / if you don't know who to tag: @baskaryan If this PR needs any additional changes, I'll be happy to make them! --------- Co-authored-by: Bagatur --- .github/CONTRIBUTING.md | 18 +- .gitignore | 5 + Makefile | 45 +- docs/.local_build.sh | 17 +- docs/api_reference/api_reference.rst | 1899 ----------------- .../integrations/arthur_tracking.ipynb | 3 +- .../guides/evaluation/comparisons.ipynb | 67 +- .../evaluation/criteria_eval_chain.ipynb | 36 +- .../evaluation/generic_agent_evaluation.ipynb | 4 +- .../openai_multi_functions_agent.ipynb | 37 +- .../how_to/add_memory_openai_functions.ipynb | 13 +- ...unctions-with-openai-functions-agent.ipynb | 46 +- .../use_toolkits_with_openai_functions.ipynb | 8 +- .../document_comparison_toolkit.ipynb | 21 +- .../modules/agents/toolkits/office365.ipynb | 20 +- .../tools/integrations/dataforseo.ipynb | 21 +- .../tools/integrations/metaphor_search.ipynb | 7 +- .../agents/tools/integrations/zapier.ipynb | 2 +- .../callbacks/integrations/infino.ipynb | 58 +- .../modules/chains/additional/cpal.ipynb | 30 +- .../modules/chains/additional/flare.ipynb | 13 +- .../additional/graph_hugegraph_qa.ipynb | 22 +- .../chains/additional/graph_kuzu_qa.ipynb | 29 +- .../chains/additional/graph_sparql_qa.ipynb | 574 ++--- .../openai_functions_retrieval_qa.ipynb | 40 +- .../chains/additional/openapi_openai.ipynb | 8 +- .../chains/popular/openai_functions.ipynb | 90 +- .../integrations/brave_search.ipynb | 4 +- .../integrations/datadog_logs.ipynb | 6 +- .../integrations/google_drive.ipynb | 8 +- .../integrations/grobid.ipynb | 2 +- .../integrations/merge_doc_loader.ipynb | 11 +- .../document_loaders/integrations/mhtml.ipynb | 4 +- .../integrations/open_city_data.ipynb | 8 +- .../integrations/org_mode.ipynb | 4 +- .../integrations/pandas_dataframe.ipynb | 2 +- .../integrations/recursive_url_loader.ipynb | 14 +- .../document_loaders/integrations/rst.ipynb | 4 +- .../integrations/source_code.ipynb | 9 +- .../integrations/tencent_cos_directory.ipynb | 8 +- .../integrations/tencent_cos_file.ipynb | 8 +- .../integrations/web_base.ipynb | 533 ++--- .../markdown_header_metadata.ipynb | 5 +- .../how_to/MultiQueryRetriever.ipynb | 38 +- .../self_query/myscale_self_query.ipynb | 98 +- .../amazon_kendra_retriever.ipynb | 4 +- .../integrations/docarray_retriever.ipynb | 143 +- .../integrations/merger_retriever.ipynb | 25 +- .../integrations/zep_memorystore.ipynb | 6 +- .../integrations/clarifai.ipynb | 12 +- .../integrations/spacy_embedding.ipynb | 20 +- .../alibabacloud_opensearch.ipynb | 2 +- .../vectorstores/integrations/awadb.ipynb | 9 +- .../vectorstores/integrations/cassandra.ipynb | 33 +- .../vectorstores/integrations/chroma.ipynb | 30 +- .../vectorstores/integrations/clarifai.ipynb | 38 +- .../integrations/clickhouse.ipynb | 22 +- .../vectorstores/integrations/marqo.ipynb | 45 +- .../integrations/mongodb_atlas.ipynb | 436 ++-- .../vectorstores/integrations/pgvector.ipynb | 7 +- .../vectorstores/integrations/redis.ipynb | 7 +- .../vectorstores/integrations/rockset.ipynb | 30 +- .../integrations/singlestoredb.ipynb | 6 +- .../vectorstores/integrations/starrocks.ipynb | 26 +- .../vectorstores/integrations/vectara.ipynb | 38 +- .../cassandra_chat_message_history.ipynb | 26 +- .../integrations/google_vertex_ai_palm.ipynb | 4 +- .../amazon_api_gateway_example.ipynb | 36 +- .../models/llms/integrations/clarifai.ipynb | 12 +- .../llms/integrations/huggingface_hub.ipynb | 20 +- .../models/llms/integrations/llamacpp.ipynb | 2 +- .../models/llms/integrations/octoai.ipynb | 18 +- .../models/llms/integrations/openllm.ipynb | 2 +- ...tter-the-algorithm-analysis-deeplake.ipynb | 1 - .../document-context-aware-QA.ipynb | 26 +- .../semantic-search-over-chat.ipynb | 2 +- poetry.lock | 160 +- pyproject.toml | 1 + 78 files changed, 1794 insertions(+), 3354 deletions(-) delete mode 100644 docs/api_reference/api_reference.rst diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 0453f2c61da50..63dfbc03018bc 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -224,30 +224,38 @@ When you run `poetry install`, the `langchain` package is installed as editable ### Contribute Documentation -Docs are largely autogenerated by [sphinx](https://www.sphinx-doc.org/en/master/) from the code. +The docs directory contains Documentation and API Reference. +Documentation is built using [Docusaurus 2](https://docusaurus.io/). + +API Reference are largely autogenerated by [sphinx](https://www.sphinx-doc.org/en/master/) from the code. For that reason, we ask that you add good documentation to all classes and methods. Similar to linting, we recognize documentation can be annoying. If you do not want to do it, please contact a project maintainer, and they can help you with it. We do not want this to be a blocker for good code getting contributed. ### Build Documentation Locally +In the following commands, the prefix `api_` indicates that those are operations for the API Reference. + Before building the documentation, it is always a good idea to clean the build directory: ```bash make docs_clean +make api_docs_clean ``` -Next, you can run the linkchecker to make sure all links are valid: +Next, you can build the documentation as outlined below: ```bash -make docs_linkcheck +make docs_build +make api_docs_build ``` -Finally, you can build the documentation as outlined below: +Finally, you can run the linkchecker to make sure all links are valid: ```bash -make docs_build +make docs_linkcheck +make api_docs_linkcheck ``` ## 🏭 Release Process diff --git a/.gitignore b/.gitignore index 2d9e9ccdf37cd..75ef042f7dbc8 100644 --- a/.gitignore +++ b/.gitignore @@ -161,7 +161,12 @@ docs/node_modules/ docs/.docusaurus/ docs/.cache-loader/ docs/_dist +docs/api_reference/api_reference.rst docs/api_reference/_build +docs/api_reference/*/ +!docs/api_reference/_static/ +!docs/api_reference/templates/ +!docs/api_reference/themes/ docs/docs_skeleton/build docs/docs_skeleton/node_modules docs/docs_skeleton/yarn.lock diff --git a/Makefile b/Makefile index 99fd1ac6e00c7..091284e9d8527 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,4 @@ -.PHONY: all clean format lint test tests test_watch integration_tests docker_tests help extended_tests +.PHONY: all clean docs_build docs_clean docs_linkcheck api_docs_build api_docs_clean api_docs_linkcheck format lint test tests test_watch integration_tests docker_tests help extended_tests # Default target executed when no arguments are given to make. all: help @@ -14,6 +14,33 @@ coverage: --cov-report xml \ --cov-report term-missing:skip-covered +###################### +# DOCUMENTATION +###################### + +clean: docs_clean api_docs_clean + + +docs_build: + docs/.local_build.sh + +docs_clean: + rm -r docs/_dist + +docs_linkcheck: + poetry run linkchecker docs/_dist/docs_skeleton/ --ignore-url node_modules + +api_docs_build: + poetry run python docs/api_reference/create_api_rst.py + cd docs/api_reference && poetry run make html + +api_docs_clean: + rm -f docs/api_reference/api_reference.rst + cd docs/api_reference && poetry run make clean + +api_docs_linkcheck: + poetry run linkchecker docs/api_reference/_build/html/index.html + # Define a variable for the test file path. TEST_FILE ?= tests/unit_tests/ @@ -36,22 +63,6 @@ docker_tests: docker build -t my-langchain-image:test . docker run --rm my-langchain-image:test -###################### -# DOCUMENTATION -###################### - -docs_compile: - poetry run nbdoc_build --srcdir $(srcdir) - -docs_build: - cd docs && poetry run make html - -docs_clean: - cd docs && poetry run make clean - -docs_linkcheck: - poetry run linkchecker docs/_build/html/index.html - ###################### # LINTING AND FORMATTING ###################### diff --git a/docs/.local_build.sh b/docs/.local_build.sh index ee0b743250828..d5f5fd918421a 100755 --- a/docs/.local_build.sh +++ b/docs/.local_build.sh @@ -1,10 +1,15 @@ -mkdir _dist +#!/usr/bin/env bash + +set -o errexit +set -o nounset +set -o pipefail +set -o xtrace + +SCRIPT_DIR="$(cd "$(dirname "$0")"; pwd)" +cd "${SCRIPT_DIR}" + +mkdir -p _dist/docs_skeleton cp -r {docs_skeleton,snippets} _dist -mkdir -p _dist/docs_skeleton/static/api_reference -cd api_reference -poetry run make html -cp -r _build/* ../_dist/docs_skeleton/static/api_reference -cd .. cp -r extras/* _dist/docs_skeleton/docs cd _dist/docs_skeleton poetry run nbdoc_build diff --git a/docs/api_reference/api_reference.rst b/docs/api_reference/api_reference.rst deleted file mode 100644 index 95043e3a1e337..0000000000000 --- a/docs/api_reference/api_reference.rst +++ /dev/null @@ -1,1899 +0,0 @@ -.. _api_reference: - -============= -API Reference -============= - -:mod:`langchain.agents`: Agents -================================ - -.. automodule:: langchain.agents - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: agents - :template: class.rst - - agents.agent.Agent - agents.agent.AgentExecutor - agents.agent.AgentOutputParser - agents.agent.BaseMultiActionAgent - agents.agent.BaseSingleActionAgent - agents.agent.ExceptionTool - agents.agent.LLMSingleActionAgent - agents.agent_toolkits.azure_cognitive_services.toolkit.AzureCognitiveServicesToolkit - agents.agent_toolkits.base.BaseToolkit - agents.agent_toolkits.file_management.toolkit.FileManagementToolkit - agents.agent_toolkits.gmail.toolkit.GmailToolkit - agents.agent_toolkits.jira.toolkit.JiraToolkit - agents.agent_toolkits.json.toolkit.JsonToolkit - agents.agent_toolkits.nla.tool.NLATool - agents.agent_toolkits.nla.toolkit.NLAToolkit - agents.agent_toolkits.office365.toolkit.O365Toolkit - agents.agent_toolkits.openapi.planner.RequestsDeleteToolWithParsing - agents.agent_toolkits.openapi.planner.RequestsGetToolWithParsing - agents.agent_toolkits.openapi.planner.RequestsPatchToolWithParsing - agents.agent_toolkits.openapi.planner.RequestsPostToolWithParsing - agents.agent_toolkits.openapi.toolkit.OpenAPIToolkit - agents.agent_toolkits.openapi.toolkit.RequestsToolkit - agents.agent_toolkits.playwright.toolkit.PlayWrightBrowserToolkit - agents.agent_toolkits.powerbi.toolkit.PowerBIToolkit - agents.agent_toolkits.spark_sql.toolkit.SparkSQLToolkit - agents.agent_toolkits.sql.toolkit.SQLDatabaseToolkit - agents.agent_toolkits.vectorstore.toolkit.VectorStoreInfo - agents.agent_toolkits.vectorstore.toolkit.VectorStoreRouterToolkit - agents.agent_toolkits.vectorstore.toolkit.VectorStoreToolkit - agents.agent_toolkits.zapier.toolkit.ZapierToolkit - agents.agent_types.AgentType - agents.chat.base.ChatAgent - agents.chat.output_parser.ChatOutputParser - agents.conversational.base.ConversationalAgent - agents.conversational.output_parser.ConvoOutputParser - agents.conversational_chat.base.ConversationalChatAgent - agents.conversational_chat.output_parser.ConvoOutputParser - agents.mrkl.base.ChainConfig - agents.mrkl.base.MRKLChain - agents.mrkl.base.ZeroShotAgent - agents.mrkl.output_parser.MRKLOutputParser - agents.openai_functions_agent.base.OpenAIFunctionsAgent - agents.openai_functions_multi_agent.base.OpenAIMultiFunctionsAgent - agents.react.base.ReActChain - agents.react.base.ReActDocstoreAgent - agents.react.base.ReActTextWorldAgent - agents.react.output_parser.ReActOutputParser - agents.schema.AgentScratchPadChatPromptTemplate - agents.self_ask_with_search.base.SelfAskWithSearchAgent - agents.self_ask_with_search.base.SelfAskWithSearchChain - agents.self_ask_with_search.output_parser.SelfAskOutputParser - agents.structured_chat.base.StructuredChatAgent - agents.structured_chat.output_parser.StructuredChatOutputParser - agents.structured_chat.output_parser.StructuredChatOutputParserWithRetries - agents.tools.InvalidTool - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: agents - - agents.agent_toolkits.csv.base.create_csv_agent - agents.agent_toolkits.json.base.create_json_agent - agents.agent_toolkits.openapi.base.create_openapi_agent - agents.agent_toolkits.openapi.planner.create_openapi_agent - agents.agent_toolkits.openapi.spec.dereference_refs - agents.agent_toolkits.openapi.spec.reduce_openapi_spec - agents.agent_toolkits.pandas.base.create_pandas_dataframe_agent - agents.agent_toolkits.powerbi.base.create_pbi_agent - agents.agent_toolkits.powerbi.chat_base.create_pbi_chat_agent - agents.agent_toolkits.python.base.create_python_agent - agents.agent_toolkits.spark.base.create_spark_dataframe_agent - agents.agent_toolkits.spark_sql.base.create_spark_sql_agent - agents.agent_toolkits.sql.base.create_sql_agent - agents.agent_toolkits.vectorstore.base.create_vectorstore_agent - agents.agent_toolkits.vectorstore.base.create_vectorstore_router_agent - agents.initialize.initialize_agent - agents.load_tools.get_all_tool_names - agents.load_tools.load_huggingface_tool - agents.load_tools.load_tools - agents.loading.load_agent - agents.loading.load_agent_from_config - agents.utils.validate_tools_single_input - -:mod:`langchain.base_language`: Base Language -============================================== - -.. automodule:: langchain.base_language - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: base_language - :template: class.rst - - base_language.BaseLanguageModel - -:mod:`langchain.cache`: Cache -============================== - -.. automodule:: langchain.cache - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: cache - :template: class.rst - - cache.BaseCache - cache.FullLLMCache - cache.GPTCache - cache.InMemoryCache - cache.MomentoCache - cache.RedisCache - cache.RedisSemanticCache - cache.SQLAlchemyCache - cache.SQLiteCache - -:mod:`langchain.callbacks`: Callbacks -====================================== - -.. automodule:: langchain.callbacks - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: callbacks - :template: class.rst - - callbacks.aim_callback.AimCallbackHandler - callbacks.argilla_callback.ArgillaCallbackHandler - callbacks.arize_callback.ArizeCallbackHandler - callbacks.arthur_callback.ArthurCallbackHandler - callbacks.base.AsyncCallbackHandler - callbacks.base.BaseCallbackHandler - callbacks.base.BaseCallbackManager - callbacks.clearml_callback.ClearMLCallbackHandler - callbacks.comet_ml_callback.CometCallbackHandler - callbacks.file.FileCallbackHandler - callbacks.flyte_callback.FlyteCallbackHandler - callbacks.human.HumanApprovalCallbackHandler - callbacks.human.HumanRejectedException - callbacks.infino_callback.InfinoCallbackHandler - callbacks.manager.AsyncCallbackManager - callbacks.manager.AsyncCallbackManagerForChainRun - callbacks.manager.AsyncCallbackManagerForLLMRun - callbacks.manager.AsyncCallbackManagerForRetrieverRun - callbacks.manager.AsyncCallbackManagerForToolRun - callbacks.manager.AsyncParentRunManager - callbacks.manager.AsyncRunManager - callbacks.manager.BaseRunManager - callbacks.manager.CallbackManager - callbacks.manager.CallbackManagerForChainRun - callbacks.manager.CallbackManagerForLLMRun - callbacks.manager.CallbackManagerForRetrieverRun - callbacks.manager.CallbackManagerForToolRun - callbacks.manager.ParentRunManager - callbacks.manager.RunManager - callbacks.mlflow_callback.MlflowCallbackHandler - callbacks.openai_info.OpenAICallbackHandler - callbacks.promptlayer_callback.PromptLayerCallbackHandler - callbacks.stdout.StdOutCallbackHandler - callbacks.streaming_aiter.AsyncIteratorCallbackHandler - callbacks.streaming_aiter_final_only.AsyncFinalIteratorCallbackHandler - callbacks.streaming_stdout.StreamingStdOutCallbackHandler - callbacks.streaming_stdout_final_only.FinalStreamingStdOutCallbackHandler - callbacks.streamlit.mutable_expander.ChildRecord - callbacks.streamlit.mutable_expander.ChildType - callbacks.streamlit.streamlit_callback_handler.LLMThoughtState - callbacks.streamlit.streamlit_callback_handler.StreamlitCallbackHandler - callbacks.streamlit.streamlit_callback_handler.ToolRecord - callbacks.tracers.base.BaseTracer - callbacks.tracers.base.TracerException - callbacks.tracers.evaluation.EvaluatorCallbackHandler - callbacks.tracers.langchain.LangChainTracer - callbacks.tracers.langchain_v1.LangChainTracerV1 - callbacks.tracers.run_collector.RunCollectorCallbackHandler - callbacks.tracers.schemas.BaseRun - callbacks.tracers.schemas.ChainRun - callbacks.tracers.schemas.LLMRun - callbacks.tracers.schemas.Run - callbacks.tracers.schemas.ToolRun - callbacks.tracers.schemas.TracerSession - callbacks.tracers.schemas.TracerSessionBase - callbacks.tracers.schemas.TracerSessionV1 - callbacks.tracers.schemas.TracerSessionV1Base - callbacks.tracers.schemas.TracerSessionV1Create - callbacks.tracers.stdout.ConsoleCallbackHandler - callbacks.tracers.wandb.WandbRunArgs - callbacks.tracers.wandb.WandbTracer - callbacks.wandb_callback.WandbCallbackHandler - callbacks.whylabs_callback.WhyLabsCallbackHandler - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: callbacks - - callbacks.aim_callback.import_aim - callbacks.clearml_callback.import_clearml - callbacks.comet_ml_callback.import_comet_ml - callbacks.flyte_callback.analyze_text - callbacks.flyte_callback.import_flytekit - callbacks.infino_callback.import_infino - callbacks.manager.env_var_is_set - callbacks.manager.get_openai_callback - callbacks.manager.trace_as_chain_group - callbacks.manager.tracing_enabled - callbacks.manager.tracing_v2_enabled - callbacks.manager.wandb_tracing_enabled - callbacks.mlflow_callback.analyze_text - callbacks.mlflow_callback.construct_html_from_prompt_and_generation - callbacks.mlflow_callback.import_mlflow - callbacks.openai_info.get_openai_token_cost_for_model - callbacks.openai_info.standardize_model_name - callbacks.streamlit.__init__.StreamlitCallbackHandler - callbacks.tracers.langchain.log_error_once - callbacks.tracers.langchain.wait_for_all_tracers - callbacks.tracers.langchain_v1.get_headers - callbacks.tracers.stdout.elapsed - callbacks.tracers.stdout.try_json_stringify - callbacks.utils.flatten_dict - callbacks.utils.hash_string - callbacks.utils.import_pandas - callbacks.utils.import_spacy - callbacks.utils.import_textstat - callbacks.utils.load_json - callbacks.wandb_callback.analyze_text - callbacks.wandb_callback.construct_html_from_prompt_and_generation - callbacks.wandb_callback.import_wandb - callbacks.wandb_callback.load_json_to_dict - callbacks.whylabs_callback.import_langkit - -:mod:`langchain.chains`: Chains -================================ - -.. automodule:: langchain.chains - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: chains - :template: class.rst - - chains.api.base.APIChain - chains.api.openapi.chain.OpenAPIEndpointChain - chains.api.openapi.requests_chain.APIRequesterChain - chains.api.openapi.requests_chain.APIRequesterOutputParser - chains.api.openapi.response_chain.APIResponderChain - chains.api.openapi.response_chain.APIResponderOutputParser - chains.base.Chain - chains.combine_documents.base.AnalyzeDocumentChain - chains.combine_documents.base.BaseCombineDocumentsChain - chains.combine_documents.map_reduce.MapReduceDocumentsChain - chains.combine_documents.map_rerank.MapRerankDocumentsChain - chains.combine_documents.reduce.AsyncCombineDocsProtocol - chains.combine_documents.reduce.CombineDocsProtocol - chains.combine_documents.reduce.ReduceDocumentsChain - chains.combine_documents.refine.RefineDocumentsChain - chains.combine_documents.stuff.StuffDocumentsChain - chains.constitutional_ai.base.ConstitutionalChain - chains.constitutional_ai.models.ConstitutionalPrinciple - chains.conversation.base.ConversationChain - chains.conversational_retrieval.base.BaseConversationalRetrievalChain - chains.conversational_retrieval.base.ChatVectorDBChain - chains.conversational_retrieval.base.ConversationalRetrievalChain - chains.flare.base.FlareChain - chains.flare.base.QuestionGeneratorChain - chains.flare.prompts.FinishedOutputParser - chains.graph_qa.base.GraphQAChain - chains.graph_qa.cypher.GraphCypherQAChain - chains.graph_qa.hugegraph.HugeGraphQAChain - chains.graph_qa.kuzu.KuzuQAChain - chains.graph_qa.nebulagraph.NebulaGraphQAChain - chains.graph_qa.sparql.GraphSparqlQAChain - chains.hyde.base.HypotheticalDocumentEmbedder - chains.llm.LLMChain - chains.llm_bash.base.LLMBashChain - chains.llm_bash.prompt.BashOutputParser - chains.llm_checker.base.LLMCheckerChain - chains.llm_math.base.LLMMathChain - chains.llm_requests.LLMRequestsChain - chains.llm_summarization_checker.base.LLMSummarizationCheckerChain - chains.mapreduce.MapReduceChain - chains.moderation.OpenAIModerationChain - chains.natbot.base.NatBotChain - chains.natbot.crawler.ElementInViewPort - chains.openai_functions.citation_fuzzy_match.FactWithEvidence - chains.openai_functions.citation_fuzzy_match.QuestionAnswer - chains.openai_functions.openapi.SimpleRequestChain - chains.openai_functions.qa_with_structure.AnswerWithSources - chains.pal.base.PALChain - chains.prompt_selector.BasePromptSelector - chains.prompt_selector.ConditionalPromptSelector - chains.qa_generation.base.QAGenerationChain - chains.qa_with_sources.base.BaseQAWithSourcesChain - chains.qa_with_sources.base.QAWithSourcesChain - chains.qa_with_sources.loading.LoadingCallable - chains.qa_with_sources.retrieval.RetrievalQAWithSourcesChain - chains.qa_with_sources.vector_db.VectorDBQAWithSourcesChain - chains.query_constructor.base.StructuredQueryOutputParser - chains.query_constructor.ir.Comparator - chains.query_constructor.ir.Comparison - chains.query_constructor.ir.Expr - chains.query_constructor.ir.FilterDirective - chains.query_constructor.ir.Operation - chains.query_constructor.ir.Operator - chains.query_constructor.ir.StructuredQuery - chains.query_constructor.ir.Visitor - chains.query_constructor.parser.QueryTransformer - chains.query_constructor.schema.AttributeInfo - chains.question_answering.__init__.LoadingCallable - chains.retrieval_qa.base.BaseRetrievalQA - chains.retrieval_qa.base.RetrievalQA - chains.retrieval_qa.base.VectorDBQA - chains.router.base.MultiRouteChain - chains.router.base.Route - chains.router.base.RouterChain - chains.router.embedding_router.EmbeddingRouterChain - chains.router.llm_router.LLMRouterChain - chains.router.llm_router.RouterOutputParser - chains.router.multi_prompt.MultiPromptChain - chains.router.multi_retrieval_qa.MultiRetrievalQAChain - chains.sequential.SequentialChain - chains.sequential.SimpleSequentialChain - chains.sql_database.base.SQLDatabaseChain - chains.sql_database.base.SQLDatabaseSequentialChain - chains.summarize.__init__.LoadingCallable - chains.transform.TransformChain - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: chains - - chains.graph_qa.cypher.extract_cypher - chains.loading.load_chain - chains.loading.load_chain_from_config - chains.openai_functions.citation_fuzzy_match.create_citation_fuzzy_match_chain - chains.openai_functions.extraction.create_extraction_chain - chains.openai_functions.extraction.create_extraction_chain_pydantic - chains.openai_functions.openapi.get_openapi_chain - chains.openai_functions.openapi.openapi_spec_to_openai_fn - chains.openai_functions.qa_with_structure.create_qa_with_sources_chain - chains.openai_functions.qa_with_structure.create_qa_with_structure_chain - chains.openai_functions.tagging.create_tagging_chain - chains.openai_functions.tagging.create_tagging_chain_pydantic - chains.openai_functions.utils.get_llm_kwargs - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.pal.math_prompt.solution - chains.prompt_selector.is_chat_model - chains.prompt_selector.is_llm - chains.qa_with_sources.loading.load_qa_with_sources_chain - chains.query_constructor.base.load_query_constructor_chain - chains.query_constructor.parser.get_parser - chains.question_answering.__init__.load_qa_chain - chains.summarize.__init__.load_summarize_chain - -:mod:`langchain.chat_models`: Chat Models -========================================== - -.. automodule:: langchain.chat_models - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: chat_models - :template: class.rst - - chat_models.anthropic.ChatAnthropic - chat_models.azure_openai.AzureChatOpenAI - chat_models.base.BaseChatModel - chat_models.base.SimpleChatModel - chat_models.fake.FakeListChatModel - chat_models.google_palm.ChatGooglePalm - chat_models.google_palm.ChatGooglePalmError - chat_models.human.HumanInputChatModel - chat_models.openai.ChatOpenAI - chat_models.promptlayer_openai.PromptLayerChatOpenAI - chat_models.vertexai.ChatVertexAI - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: chat_models - - chat_models.google_palm.chat_with_retry - -:mod:`langchain.client`: Client -================================ - -.. automodule:: langchain.client - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: client - :template: class.rst - - client.runner_utils.InputFormatError - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: client - - client.runner_utils.run_llm - client.runner_utils.run_llm_or_chain - client.runner_utils.run_on_dataset - client.runner_utils.run_on_examples - -:mod:`langchain.docstore`: Docstore -==================================== - -.. automodule:: langchain.docstore - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: docstore - :template: class.rst - - docstore.arbitrary_fn.DocstoreFn - docstore.base.AddableMixin - docstore.base.Docstore - docstore.in_memory.InMemoryDocstore - docstore.wikipedia.Wikipedia - -:mod:`langchain.document_loaders`: Document Loaders -==================================================== - -.. automodule:: langchain.document_loaders - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: document_loaders - :template: class.rst - - document_loaders.acreom.AcreomLoader - document_loaders.airbyte_json.AirbyteJSONLoader - document_loaders.airtable.AirtableLoader - document_loaders.apify_dataset.ApifyDatasetLoader - document_loaders.arxiv.ArxivLoader - document_loaders.azlyrics.AZLyricsLoader - document_loaders.azure_blob_storage_container.AzureBlobStorageContainerLoader - document_loaders.azure_blob_storage_file.AzureBlobStorageFileLoader - document_loaders.base.BaseBlobParser - document_loaders.base.BaseLoader - document_loaders.bibtex.BibtexLoader - document_loaders.bigquery.BigQueryLoader - document_loaders.bilibili.BiliBiliLoader - document_loaders.blackboard.BlackboardLoader - document_loaders.blob_loaders.file_system.FileSystemBlobLoader - document_loaders.blob_loaders.schema.Blob - document_loaders.blob_loaders.schema.BlobLoader - document_loaders.blob_loaders.youtube_audio.YoutubeAudioLoader - document_loaders.blockchain.BlockchainDocumentLoader - document_loaders.blockchain.BlockchainType - document_loaders.brave_search.BraveSearchLoader - document_loaders.chatgpt.ChatGPTLoader - document_loaders.college_confidential.CollegeConfidentialLoader - document_loaders.confluence.ConfluenceLoader - document_loaders.confluence.ContentFormat - document_loaders.conllu.CoNLLULoader - document_loaders.csv_loader.CSVLoader - document_loaders.csv_loader.UnstructuredCSVLoader - document_loaders.cube_semantic.CubeSemanticLoader - document_loaders.dataframe.DataFrameLoader - document_loaders.diffbot.DiffbotLoader - document_loaders.directory.DirectoryLoader - document_loaders.discord.DiscordChatLoader - document_loaders.docugami.DocugamiLoader - document_loaders.duckdb_loader.DuckDBLoader - document_loaders.email.OutlookMessageLoader - document_loaders.email.UnstructuredEmailLoader - document_loaders.embaas.BaseEmbaasLoader - document_loaders.embaas.EmbaasBlobLoader - document_loaders.embaas.EmbaasDocumentExtractionParameters - document_loaders.embaas.EmbaasDocumentExtractionPayload - document_loaders.embaas.EmbaasLoader - document_loaders.epub.UnstructuredEPubLoader - document_loaders.evernote.EverNoteLoader - document_loaders.excel.UnstructuredExcelLoader - document_loaders.facebook_chat.FacebookChatLoader - document_loaders.fauna.FaunaLoader - document_loaders.figma.FigmaFileLoader - document_loaders.gcs_directory.GCSDirectoryLoader - document_loaders.gcs_file.GCSFileLoader - document_loaders.generic.GenericLoader - document_loaders.git.GitLoader - document_loaders.gitbook.GitbookLoader - document_loaders.github.BaseGitHubLoader - document_loaders.github.GitHubIssuesLoader - document_loaders.googledrive.GoogleDriveLoader - document_loaders.gutenberg.GutenbergLoader - document_loaders.helpers.FileEncoding - document_loaders.hn.HNLoader - document_loaders.html.UnstructuredHTMLLoader - document_loaders.html_bs.BSHTMLLoader - document_loaders.hugging_face_dataset.HuggingFaceDatasetLoader - document_loaders.ifixit.IFixitLoader - document_loaders.image.UnstructuredImageLoader - document_loaders.image_captions.ImageCaptionLoader - document_loaders.imsdb.IMSDbLoader - document_loaders.iugu.IuguLoader - document_loaders.joplin.JoplinLoader - document_loaders.json_loader.JSONLoader - document_loaders.larksuite.LarkSuiteDocLoader - document_loaders.markdown.UnstructuredMarkdownLoader - document_loaders.mastodon.MastodonTootsLoader - document_loaders.max_compute.MaxComputeLoader - document_loaders.mediawikidump.MWDumpLoader - document_loaders.merge.MergedDataLoader - document_loaders.mhtml.MHTMLLoader - document_loaders.modern_treasury.ModernTreasuryLoader - document_loaders.notebook.NotebookLoader - document_loaders.notion.NotionDirectoryLoader - document_loaders.notiondb.NotionDBLoader - document_loaders.obsidian.ObsidianLoader - document_loaders.odt.UnstructuredODTLoader - document_loaders.onedrive.OneDriveLoader - document_loaders.onedrive_file.OneDriveFileLoader - document_loaders.open_city_data.OpenCityDataLoader - document_loaders.org_mode.UnstructuredOrgModeLoader - document_loaders.parsers.audio.OpenAIWhisperParser - document_loaders.parsers.generic.MimeTypeBasedParser - document_loaders.parsers.grobid.GrobidParser - document_loaders.parsers.grobid.ServerUnavailableException - document_loaders.parsers.html.bs4.BS4HTMLParser - document_loaders.parsers.language.code_segmenter.CodeSegmenter - document_loaders.parsers.language.javascript.JavaScriptSegmenter - document_loaders.parsers.language.language_parser.LanguageParser - document_loaders.parsers.language.python.PythonSegmenter - document_loaders.parsers.pdf.PDFMinerParser - document_loaders.parsers.pdf.PDFPlumberParser - document_loaders.parsers.pdf.PyMuPDFParser - document_loaders.parsers.pdf.PyPDFParser - document_loaders.parsers.pdf.PyPDFium2Parser - document_loaders.parsers.txt.TextParser - document_loaders.pdf.BasePDFLoader - document_loaders.pdf.MathpixPDFLoader - document_loaders.pdf.OnlinePDFLoader - document_loaders.pdf.PDFMinerLoader - document_loaders.pdf.PDFMinerPDFasHTMLLoader - document_loaders.pdf.PDFPlumberLoader - document_loaders.pdf.PyMuPDFLoader - document_loaders.pdf.PyPDFDirectoryLoader - document_loaders.pdf.PyPDFLoader - document_loaders.pdf.PyPDFium2Loader - document_loaders.pdf.UnstructuredPDFLoader - document_loaders.powerpoint.UnstructuredPowerPointLoader - document_loaders.psychic.PsychicLoader - document_loaders.pyspark_dataframe.PySparkDataFrameLoader - document_loaders.python.PythonLoader - document_loaders.readthedocs.ReadTheDocsLoader - document_loaders.recursive_url_loader.RecursiveUrlLoader - document_loaders.reddit.RedditPostsLoader - document_loaders.roam.RoamLoader - document_loaders.rst.UnstructuredRSTLoader - document_loaders.rtf.UnstructuredRTFLoader - document_loaders.s3_directory.S3DirectoryLoader - document_loaders.s3_file.S3FileLoader - document_loaders.sitemap.SitemapLoader - document_loaders.slack_directory.SlackDirectoryLoader - document_loaders.snowflake_loader.SnowflakeLoader - document_loaders.spreedly.SpreedlyLoader - document_loaders.srt.SRTLoader - document_loaders.stripe.StripeLoader - document_loaders.telegram.TelegramChatApiLoader - document_loaders.telegram.TelegramChatFileLoader - document_loaders.tencent_cos_directory.TencentCOSDirectoryLoader - document_loaders.tencent_cos_file.TencentCOSFileLoader - document_loaders.text.TextLoader - document_loaders.tomarkdown.ToMarkdownLoader - document_loaders.toml.TomlLoader - document_loaders.trello.TrelloLoader - document_loaders.twitter.TwitterTweetLoader - document_loaders.unstructured.UnstructuredAPIFileIOLoader - document_loaders.unstructured.UnstructuredAPIFileLoader - document_loaders.unstructured.UnstructuredBaseLoader - document_loaders.unstructured.UnstructuredFileIOLoader - document_loaders.unstructured.UnstructuredFileLoader - document_loaders.url.UnstructuredURLLoader - document_loaders.url_playwright.PlaywrightURLLoader - document_loaders.url_selenium.SeleniumURLLoader - document_loaders.weather.WeatherDataLoader - document_loaders.web_base.WebBaseLoader - document_loaders.whatsapp_chat.WhatsAppChatLoader - document_loaders.wikipedia.WikipediaLoader - document_loaders.word_document.Docx2txtLoader - document_loaders.word_document.UnstructuredWordDocumentLoader - document_loaders.xml.UnstructuredXMLLoader - document_loaders.xorbits.XorbitsLoader - document_loaders.youtube.GoogleApiYoutubeLoader - document_loaders.youtube.YoutubeLoader - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: document_loaders - - document_loaders.chatgpt.concatenate_rows - document_loaders.facebook_chat.concatenate_rows - document_loaders.helpers.detect_file_encodings - document_loaders.notebook.concatenate_cells - document_loaders.notebook.remove_newlines - document_loaders.parsers.registry.get_parser - document_loaders.telegram.concatenate_rows - document_loaders.telegram.text_to_docs - document_loaders.unstructured.get_elements_from_api - document_loaders.unstructured.satisfies_min_unstructured_version - document_loaders.unstructured.validate_unstructured_version - document_loaders.whatsapp_chat.concatenate_rows - -:mod:`langchain.document_transformers`: Document Transformers -============================================================== - -.. automodule:: langchain.document_transformers - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: document_transformers - :template: class.rst - - document_transformers.EmbeddingsRedundantFilter - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: document_transformers - - document_transformers.get_stateful_documents - -:mod:`langchain.embeddings`: Embeddings -======================================== - -.. automodule:: langchain.embeddings - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: embeddings - :template: class.rst - - embeddings.aleph_alpha.AlephAlphaAsymmetricSemanticEmbedding - embeddings.aleph_alpha.AlephAlphaSymmetricSemanticEmbedding - embeddings.base.Embeddings - embeddings.bedrock.BedrockEmbeddings - embeddings.cohere.CohereEmbeddings - embeddings.dashscope.DashScopeEmbeddings - embeddings.deepinfra.DeepInfraEmbeddings - embeddings.elasticsearch.ElasticsearchEmbeddings - embeddings.embaas.EmbaasEmbeddings - embeddings.embaas.EmbaasEmbeddingsPayload - embeddings.fake.FakeEmbeddings - embeddings.google_palm.GooglePalmEmbeddings - embeddings.huggingface.HuggingFaceEmbeddings - embeddings.huggingface.HuggingFaceInstructEmbeddings - embeddings.huggingface_hub.HuggingFaceHubEmbeddings - embeddings.jina.JinaEmbeddings - embeddings.llamacpp.LlamaCppEmbeddings - embeddings.minimax.MiniMaxEmbeddings - embeddings.modelscope_hub.ModelScopeEmbeddings - embeddings.mosaicml.MosaicMLInstructorEmbeddings - embeddings.octoai_embeddings.OctoAIEmbeddings - embeddings.openai.OpenAIEmbeddings - embeddings.sagemaker_endpoint.EmbeddingsContentHandler - embeddings.sagemaker_endpoint.SagemakerEndpointEmbeddings - embeddings.self_hosted.SelfHostedEmbeddings - embeddings.self_hosted_hugging_face.SelfHostedHuggingFaceEmbeddings - embeddings.self_hosted_hugging_face.SelfHostedHuggingFaceInstructEmbeddings - embeddings.spacy_embeddings.SpacyEmbeddings - embeddings.tensorflow_hub.TensorflowHubEmbeddings - embeddings.vertexai.VertexAIEmbeddings - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: embeddings - - embeddings.dashscope.embed_with_retry - embeddings.google_palm.embed_with_retry - embeddings.minimax.embed_with_retry - embeddings.openai.embed_with_retry - embeddings.self_hosted_hugging_face.load_embedding_model - -:mod:`langchain.env`: Env -========================== - -.. automodule:: langchain.env - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: env - - env.get_runtime_environment - -:mod:`langchain.evaluation`: Evaluation -======================================== - -.. automodule:: langchain.evaluation - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: evaluation - :template: class.rst - - evaluation.agents.trajectory_eval_chain.TrajectoryEval - evaluation.agents.trajectory_eval_chain.TrajectoryEvalChain - evaluation.agents.trajectory_eval_chain.TrajectoryOutputParser - evaluation.comparison.eval_chain.PairwiseStringEvalChain - evaluation.comparison.eval_chain.PairwiseStringResultOutputParser - evaluation.criteria.eval_chain.CriteriaEvalChain - evaluation.criteria.eval_chain.CriteriaResultOutputParser - evaluation.embedding_distance.base.EmbeddingDistance - evaluation.embedding_distance.base.EmbeddingDistanceEvalChain - evaluation.embedding_distance.base.PairwiseEmbeddingDistanceEvalChain - evaluation.qa.eval_chain.ContextQAEvalChain - evaluation.qa.eval_chain.CotQAEvalChain - evaluation.qa.eval_chain.QAEvalChain - evaluation.qa.generate_chain.QAGenerateChain - evaluation.run_evaluators.base.RunEvaluatorChain - evaluation.run_evaluators.base.RunEvaluatorOutputParser - evaluation.run_evaluators.implementations.ChoicesOutputParser - evaluation.run_evaluators.implementations.CriteriaOutputParser - evaluation.run_evaluators.implementations.StringRunEvaluatorInputMapper - evaluation.run_evaluators.implementations.TrajectoryInputMapper - evaluation.run_evaluators.implementations.TrajectoryRunEvalOutputParser - evaluation.schema.AgentTrajectoryEvaluator - evaluation.schema.EvaluatorType - evaluation.schema.LLMEvalChain - evaluation.schema.PairwiseStringEvaluator - evaluation.schema.StringEvaluator - evaluation.string_distance.base.PairwiseStringDistanceEvalChain - evaluation.string_distance.base.StringDistance - evaluation.string_distance.base.StringDistanceEvalChain - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: evaluation - - evaluation.loading.load_dataset - evaluation.loading.load_evaluator - evaluation.loading.load_evaluators - evaluation.run_evaluators.implementations.get_criteria_evaluator - evaluation.run_evaluators.implementations.get_qa_evaluator - evaluation.run_evaluators.implementations.get_trajectory_evaluator - -:mod:`langchain.example_generator`: Example Generator -====================================================== - -.. automodule:: langchain.example_generator - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: example_generator - - example_generator.generate_example - -:mod:`langchain.experimental`: Experimental -============================================ - -.. automodule:: langchain.experimental - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: experimental - :template: class.rst - - experimental.autonomous_agents.autogpt.memory.AutoGPTMemory - experimental.autonomous_agents.autogpt.output_parser.AutoGPTAction - experimental.autonomous_agents.autogpt.output_parser.AutoGPTOutputParser - experimental.autonomous_agents.autogpt.output_parser.BaseAutoGPTOutputParser - experimental.autonomous_agents.autogpt.prompt.AutoGPTPrompt - experimental.autonomous_agents.baby_agi.baby_agi.BabyAGI - experimental.autonomous_agents.baby_agi.task_creation.TaskCreationChain - experimental.autonomous_agents.baby_agi.task_execution.TaskExecutionChain - experimental.autonomous_agents.baby_agi.task_prioritization.TaskPrioritizationChain - experimental.generative_agents.generative_agent.GenerativeAgent - experimental.generative_agents.memory.GenerativeAgentMemory - experimental.llms.jsonformer_decoder.JsonFormer - experimental.llms.rellm_decoder.RELLM - experimental.plan_and_execute.agent_executor.PlanAndExecute - experimental.plan_and_execute.executors.base.BaseExecutor - experimental.plan_and_execute.executors.base.ChainExecutor - experimental.plan_and_execute.planners.base.BasePlanner - experimental.plan_and_execute.planners.base.LLMPlanner - experimental.plan_and_execute.planners.chat_planner.PlanningOutputParser - experimental.plan_and_execute.schema.BaseStepContainer - experimental.plan_and_execute.schema.ListStepContainer - experimental.plan_and_execute.schema.Plan - experimental.plan_and_execute.schema.PlanOutputParser - experimental.plan_and_execute.schema.Step - experimental.plan_and_execute.schema.StepResponse - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: experimental - - experimental.autonomous_agents.autogpt.output_parser.preprocess_json_input - experimental.autonomous_agents.autogpt.prompt_generator.get_prompt - experimental.llms.jsonformer_decoder.import_jsonformer - experimental.llms.rellm_decoder.import_rellm - experimental.plan_and_execute.executors.agent_executor.load_agent_executor - experimental.plan_and_execute.planners.chat_planner.load_chat_planner - -:mod:`langchain.formatting`: Formatting -======================================== - -.. automodule:: langchain.formatting - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: formatting - :template: class.rst - - formatting.StrictFormatter - -:mod:`langchain.graphs`: Graphs -================================ - -.. automodule:: langchain.graphs - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: graphs - :template: class.rst - - graphs.networkx_graph.KnowledgeTriple - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: graphs - - graphs.networkx_graph.get_entities - graphs.networkx_graph.parse_triples - -:mod:`langchain.indexes`: Indexes -================================== - -.. automodule:: langchain.indexes - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: indexes - :template: class.rst - - indexes.graph.GraphIndexCreator - indexes.vectorstore.VectorStoreIndexWrapper - indexes.vectorstore.VectorstoreIndexCreator - -:mod:`langchain.input`: Input -============================== - -.. automodule:: langchain.input - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: input - - input.get_bolded_text - input.get_color_mapping - input.get_colored_text - input.print_text - -:mod:`langchain.llms`: LLMs -============================ - -.. automodule:: langchain.llms - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: llms - :template: class.rst - - llms.ai21.AI21 - llms.ai21.AI21PenaltyData - llms.aleph_alpha.AlephAlpha - llms.amazon_api_gateway.AmazonAPIGateway - llms.anthropic.Anthropic - llms.anyscale.Anyscale - llms.aviary.Aviary - llms.azureml_endpoint.AzureMLEndpointClient - llms.azureml_endpoint.AzureMLOnlineEndpoint - llms.azureml_endpoint.DollyContentFormatter - llms.azureml_endpoint.HFContentFormatter - llms.azureml_endpoint.OSSContentFormatter - llms.bananadev.Banana - llms.base.BaseLLM - llms.base.LLM - llms.baseten.Baseten - llms.beam.Beam - llms.bedrock.Bedrock - llms.cerebriumai.CerebriumAI - llms.clarifai.Clarifai - llms.cohere.Cohere - llms.ctransformers.CTransformers - llms.databricks.Databricks - llms.deepinfra.DeepInfra - llms.fake.FakeListLLM - llms.forefrontai.ForefrontAI - llms.google_palm.GooglePalm - llms.gooseai.GooseAI - llms.gpt4all.GPT4All - llms.huggingface_endpoint.HuggingFaceEndpoint - llms.huggingface_hub.HuggingFaceHub - llms.huggingface_pipeline.HuggingFacePipeline - llms.huggingface_text_gen_inference.HuggingFaceTextGenInference - llms.human.HumanInputLLM - llms.llamacpp.LlamaCpp - llms.manifest.ManifestWrapper - llms.modal.Modal - llms.mosaicml.MosaicML - llms.nlpcloud.NLPCloud - llms.octoai_endpoint.OctoAIEndpoint - llms.openai.AzureOpenAI - llms.openai.BaseOpenAI - llms.openai.OpenAI - llms.openai.OpenAIChat - llms.openllm.IdentifyingParams - llms.openllm.OpenLLM - llms.openlm.OpenLM - llms.petals.Petals - llms.pipelineai.PipelineAI - llms.predictionguard.PredictionGuard - llms.promptlayer_openai.PromptLayerOpenAI - llms.promptlayer_openai.PromptLayerOpenAIChat - llms.replicate.Replicate - llms.rwkv.RWKV - llms.sagemaker_endpoint.ContentHandlerBase - llms.sagemaker_endpoint.LLMContentHandler - llms.sagemaker_endpoint.SagemakerEndpoint - llms.self_hosted.SelfHostedPipeline - llms.self_hosted_hugging_face.SelfHostedHuggingFaceLLM - llms.stochasticai.StochasticAI - llms.textgen.TextGen - llms.vertexai.VertexAI - llms.writer.Writer - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: llms - - llms.aviary.get_completions - llms.aviary.get_models - llms.base.create_base_retry_decorator - llms.base.get_prompts - llms.base.update_cache - llms.cohere.completion_with_retry - llms.databricks.get_default_api_token - llms.databricks.get_default_host - llms.databricks.get_repl_context - llms.google_palm.generate_with_retry - llms.loading.load_llm - llms.loading.load_llm_from_config - llms.openai.completion_with_retry - llms.openai.update_token_usage - llms.utils.enforce_stop_tokens - llms.vertexai.completion_with_retry - llms.vertexai.is_codey_model - -:mod:`langchain.load`: Load -============================ - -.. automodule:: langchain.load - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: load - :template: class.rst - - load.serializable.BaseSerialized - load.serializable.Serializable - load.serializable.SerializedConstructor - load.serializable.SerializedNotImplemented - load.serializable.SerializedSecret - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: load - - load.dump.default - load.dump.dumpd - load.dump.dumps - load.load.loads - load.serializable.to_json_not_implemented - -:mod:`langchain.math_utils`: Math Utils -======================================== - -.. automodule:: langchain.math_utils - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: math_utils - - math_utils.cosine_similarity - math_utils.cosine_similarity_top_k - -:mod:`langchain.memory`: Memory -================================ - -.. automodule:: langchain.memory - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: memory - :template: class.rst - - memory.buffer.ConversationBufferMemory - memory.buffer.ConversationStringBufferMemory - memory.buffer_window.ConversationBufferWindowMemory - memory.chat_memory.BaseChatMemory - memory.chat_message_histories.cassandra.CassandraChatMessageHistory - memory.chat_message_histories.cosmos_db.CosmosDBChatMessageHistory - memory.chat_message_histories.dynamodb.DynamoDBChatMessageHistory - memory.chat_message_histories.file.FileChatMessageHistory - memory.chat_message_histories.firestore.FirestoreChatMessageHistory - memory.chat_message_histories.in_memory.ChatMessageHistory - memory.chat_message_histories.momento.MomentoChatMessageHistory - memory.chat_message_histories.mongodb.MongoDBChatMessageHistory - memory.chat_message_histories.postgres.PostgresChatMessageHistory - memory.chat_message_histories.redis.RedisChatMessageHistory - memory.chat_message_histories.sql.SQLChatMessageHistory - memory.chat_message_histories.zep.ZepChatMessageHistory - memory.combined.CombinedMemory - memory.entity.BaseEntityStore - memory.entity.ConversationEntityMemory - memory.entity.InMemoryEntityStore - memory.entity.RedisEntityStore - memory.entity.SQLiteEntityStore - memory.kg.ConversationKGMemory - memory.motorhead_memory.MotorheadMemory - memory.readonly.ReadOnlySharedMemory - memory.simple.SimpleMemory - memory.summary.ConversationSummaryMemory - memory.summary.SummarizerMixin - memory.summary_buffer.ConversationSummaryBufferMemory - memory.token_buffer.ConversationTokenBufferMemory - memory.vectorstore.VectorStoreRetrieverMemory - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: memory - - memory.chat_message_histories.sql.create_message_model - memory.utils.get_prompt_input_key - -:mod:`langchain.output_parsers`: Output Parsers -================================================ - -.. automodule:: langchain.output_parsers - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: output_parsers - :template: class.rst - - output_parsers.boolean.BooleanOutputParser - output_parsers.combining.CombiningOutputParser - output_parsers.datetime.DatetimeOutputParser - output_parsers.enum.EnumOutputParser - output_parsers.fix.OutputFixingParser - output_parsers.list.CommaSeparatedListOutputParser - output_parsers.list.ListOutputParser - output_parsers.openai_functions.JsonKeyOutputFunctionsParser - output_parsers.openai_functions.JsonOutputFunctionsParser - output_parsers.openai_functions.OutputFunctionsParser - output_parsers.openai_functions.PydanticAttrOutputFunctionsParser - output_parsers.openai_functions.PydanticOutputFunctionsParser - output_parsers.pydantic.PydanticOutputParser - output_parsers.rail_parser.GuardrailsOutputParser - output_parsers.regex.RegexParser - output_parsers.regex_dict.RegexDictParser - output_parsers.retry.RetryOutputParser - output_parsers.retry.RetryWithErrorOutputParser - output_parsers.structured.ResponseSchema - output_parsers.structured.StructuredOutputParser - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: output_parsers - - output_parsers.json.parse_and_check_json_markdown - output_parsers.json.parse_json_markdown - output_parsers.loading.load_output_parser - -:mod:`langchain.prompts`: Prompts -================================== - -.. automodule:: langchain.prompts - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: prompts - :template: class.rst - - prompts.base.StringPromptTemplate - prompts.base.StringPromptValue - prompts.chat.AIMessagePromptTemplate - prompts.chat.BaseChatPromptTemplate - prompts.chat.BaseMessagePromptTemplate - prompts.chat.BaseStringMessagePromptTemplate - prompts.chat.ChatMessagePromptTemplate - prompts.chat.ChatPromptTemplate - prompts.chat.ChatPromptValue - prompts.chat.HumanMessagePromptTemplate - prompts.chat.MessagesPlaceholder - prompts.chat.SystemMessagePromptTemplate - prompts.example_selector.base.BaseExampleSelector - prompts.example_selector.length_based.LengthBasedExampleSelector - prompts.example_selector.ngram_overlap.NGramOverlapExampleSelector - prompts.example_selector.semantic_similarity.MaxMarginalRelevanceExampleSelector - prompts.example_selector.semantic_similarity.SemanticSimilarityExampleSelector - prompts.few_shot.FewShotPromptTemplate - prompts.few_shot_with_templates.FewShotPromptWithTemplates - prompts.pipeline.PipelinePromptTemplate - prompts.prompt.PromptTemplate - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: prompts - - prompts.base.check_valid_template - prompts.base.jinja2_formatter - prompts.base.validate_jinja2 - prompts.example_selector.ngram_overlap.ngram_overlap_score - prompts.example_selector.semantic_similarity.sorted_values - prompts.loading.load_prompt - prompts.loading.load_prompt_from_config - -:mod:`langchain.requests`: Requests -==================================== - -.. automodule:: langchain.requests - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: requests - :template: class.rst - - requests.Requests - requests.TextRequestsWrapper - -:mod:`langchain.retrievers`: Retrievers -======================================== - -.. automodule:: langchain.retrievers - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: retrievers - :template: class.rst - - retrievers.arxiv.ArxivRetriever - retrievers.azure_cognitive_search.AzureCognitiveSearchRetriever - retrievers.chatgpt_plugin_retriever.ChatGPTPluginRetriever - retrievers.contextual_compression.ContextualCompressionRetriever - retrievers.chaindesk.ChaindeskRetriever - retrievers.docarray.DocArrayRetriever - retrievers.docarray.SearchType - retrievers.document_compressors.base.BaseDocumentCompressor - retrievers.document_compressors.base.DocumentCompressorPipeline - retrievers.document_compressors.chain_extract.LLMChainExtractor - retrievers.document_compressors.chain_extract.NoOutputParser - retrievers.document_compressors.chain_filter.LLMChainFilter - retrievers.document_compressors.cohere_rerank.CohereRerank - retrievers.document_compressors.embeddings_filter.EmbeddingsFilter - retrievers.elastic_search_bm25.ElasticSearchBM25Retriever - retrievers.kendra.AdditionalResultAttribute - retrievers.kendra.AdditionalResultAttributeValue - retrievers.kendra.AmazonKendraRetriever - retrievers.kendra.DocumentAttribute - retrievers.kendra.DocumentAttributeValue - retrievers.kendra.Highlight - retrievers.kendra.QueryResult - retrievers.kendra.QueryResultItem - retrievers.kendra.RetrieveResult - retrievers.kendra.RetrieveResultItem - retrievers.kendra.TextWithHighLights - retrievers.knn.KNNRetriever - retrievers.llama_index.LlamaIndexGraphRetriever - retrievers.llama_index.LlamaIndexRetriever - retrievers.merger_retriever.MergerRetriever - retrievers.metal.MetalRetriever - retrievers.milvus.MilvusRetriever - retrievers.multi_query.LineList - retrievers.multi_query.LineListOutputParser - retrievers.multi_query.MultiQueryRetriever - retrievers.pinecone_hybrid_search.PineconeHybridSearchRetriever - retrievers.pubmed.PubMedRetriever - retrievers.remote_retriever.RemoteLangChainRetriever - retrievers.self_query.base.SelfQueryRetriever - retrievers.self_query.chroma.ChromaTranslator - retrievers.self_query.myscale.MyScaleTranslator - retrievers.self_query.pinecone.PineconeTranslator - retrievers.self_query.qdrant.QdrantTranslator - retrievers.self_query.weaviate.WeaviateTranslator - retrievers.svm.SVMRetriever - retrievers.tfidf.TFIDFRetriever - retrievers.time_weighted_retriever.TimeWeightedVectorStoreRetriever - retrievers.vespa_retriever.VespaRetriever - retrievers.weaviate_hybrid_search.WeaviateHybridSearchRetriever - retrievers.wikipedia.WikipediaRetriever - retrievers.zep.ZepRetriever - retrievers.zilliz.ZillizRetriever - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: retrievers - - retrievers.document_compressors.chain_extract.default_get_input - retrievers.document_compressors.chain_filter.default_get_input - retrievers.kendra.clean_excerpt - retrievers.kendra.combined_text - retrievers.knn.create_index - retrievers.milvus.MilvusRetreiver - retrievers.pinecone_hybrid_search.create_index - retrievers.pinecone_hybrid_search.hash_text - retrievers.self_query.myscale.DEFAULT_COMPOSER - retrievers.self_query.myscale.FUNCTION_COMPOSER - retrievers.svm.create_index - retrievers.zilliz.ZillizRetreiver - -:mod:`langchain.schema`: Schema -================================ - -.. automodule:: langchain.schema - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: schema - :template: class.rst - - schema.agent.AgentFinish - schema.document.BaseDocumentTransformer - schema.document.Document - schema.memory.BaseChatMessageHistory - schema.memory.BaseMemory - schema.messages.AIMessage - schema.messages.BaseMessage - schema.messages.ChatMessage - schema.messages.FunctionMessage - schema.messages.HumanMessage - schema.messages.SystemMessage - schema.output.ChatGeneration - schema.output.ChatResult - schema.output.Generation - schema.output.LLMResult - schema.output.RunInfo - schema.output_parser.BaseLLMOutputParser - schema.output_parser.BaseOutputParser - schema.output_parser.NoOpOutputParser - schema.output_parser.OutputParserException - schema.prompt.PromptValue - schema.prompt_template.BasePromptTemplate - schema.retriever.BaseRetriever - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: schema - - schema.messages.get_buffer_string - schema.messages.messages_from_dict - schema.messages.messages_to_dict - schema.prompt_template.format_document - -:mod:`langchain.server`: Server -================================ - -.. automodule:: langchain.server - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: server - - server.main - -:mod:`langchain.sql_database`: Sql Database -============================================ - -.. automodule:: langchain.sql_database - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: sql_database - - sql_database.truncate_word - -:mod:`langchain.text_splitter`: Text Splitter -============================================== - -.. automodule:: langchain.text_splitter - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: text_splitter - :template: class.rst - - text_splitter.CharacterTextSplitter - text_splitter.HeaderType - text_splitter.Language - text_splitter.LatexTextSplitter - text_splitter.LineType - text_splitter.MarkdownTextSplitter - text_splitter.NLTKTextSplitter - text_splitter.PythonCodeTextSplitter - text_splitter.RecursiveCharacterTextSplitter - text_splitter.SentenceTransformersTokenTextSplitter - text_splitter.SpacyTextSplitter - text_splitter.TextSplitter - text_splitter.TokenTextSplitter - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: text_splitter - - text_splitter.split_text_on_tokens - -:mod:`langchain.tools`: Tools -============================== - -.. automodule:: langchain.tools - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: tools - :template: class.rst - - tools.arxiv.tool.ArxivQueryRun - tools.azure_cognitive_services.form_recognizer.AzureCogsFormRecognizerTool - tools.azure_cognitive_services.image_analysis.AzureCogsImageAnalysisTool - tools.azure_cognitive_services.speech2text.AzureCogsSpeech2TextTool - tools.azure_cognitive_services.text2speech.AzureCogsText2SpeechTool - tools.base.BaseTool - tools.base.ChildTool - tools.base.SchemaAnnotationError - tools.base.StructuredTool - tools.base.Tool - tools.base.ToolException - tools.base.ToolMetaclass - tools.bing_search.tool.BingSearchResults - tools.bing_search.tool.BingSearchRun - tools.brave_search.tool.BraveSearch - tools.convert_to_openai.FunctionDescription - tools.dataforseo_api_search.tool.DataForSeoAPISearchResults - tools.dataforseo_api_search.tool.DataForSeoAPISearchRun - tools.ddg_search.tool.DuckDuckGoSearchResults - tools.ddg_search.tool.DuckDuckGoSearchRun - tools.file_management.copy.CopyFileTool - tools.file_management.copy.FileCopyInput - tools.file_management.delete.DeleteFileTool - tools.file_management.delete.FileDeleteInput - tools.file_management.file_search.FileSearchInput - tools.file_management.file_search.FileSearchTool - tools.file_management.list_dir.DirectoryListingInput - tools.file_management.list_dir.ListDirectoryTool - tools.file_management.move.FileMoveInput - tools.file_management.move.MoveFileTool - tools.file_management.read.ReadFileInput - tools.file_management.read.ReadFileTool - tools.file_management.utils.BaseFileToolMixin - tools.file_management.utils.FileValidationError - tools.file_management.write.WriteFileInput - tools.file_management.write.WriteFileTool - tools.gmail.base.GmailBaseTool - tools.gmail.create_draft.CreateDraftSchema - tools.gmail.create_draft.GmailCreateDraft - tools.gmail.get_message.GmailGetMessage - tools.gmail.get_message.SearchArgsSchema - tools.gmail.get_thread.GetThreadSchema - tools.gmail.get_thread.GmailGetThread - tools.gmail.search.GmailSearch - tools.gmail.search.Resource - tools.gmail.search.SearchArgsSchema - tools.gmail.send_message.GmailSendMessage - tools.gmail.send_message.SendMessageSchema - tools.google_places.tool.GooglePlacesSchema - tools.google_places.tool.GooglePlacesTool - tools.google_search.tool.GoogleSearchResults - tools.google_search.tool.GoogleSearchRun - tools.google_serper.tool.GoogleSerperResults - tools.google_serper.tool.GoogleSerperRun - tools.graphql.tool.BaseGraphQLTool - tools.human.tool.HumanInputRun - tools.ifttt.IFTTTWebhook - tools.jira.tool.JiraAction - tools.json.tool.JsonGetValueTool - tools.json.tool.JsonListKeysTool - tools.json.tool.JsonSpec - tools.metaphor_search.tool.MetaphorSearchResults - tools.office365.base.O365BaseTool - tools.office365.create_draft_message.CreateDraftMessageSchema - tools.office365.create_draft_message.O365CreateDraftMessage - tools.office365.events_search.O365SearchEvents - tools.office365.events_search.SearchEventsInput - tools.office365.messages_search.O365SearchEmails - tools.office365.messages_search.SearchEmailsInput - tools.office365.send_event.O365SendEvent - tools.office365.send_event.SendEventSchema - tools.office365.send_message.O365SendMessage - tools.office365.send_message.SendMessageSchema - tools.openapi.utils.api_models.APIOperation - tools.openapi.utils.api_models.APIProperty - tools.openapi.utils.api_models.APIPropertyBase - tools.openapi.utils.api_models.APIPropertyLocation - tools.openapi.utils.api_models.APIRequestBody - tools.openapi.utils.api_models.APIRequestBodyProperty - tools.openweathermap.tool.OpenWeatherMapQueryRun - tools.playwright.base.BaseBrowserTool - tools.playwright.click.ClickTool - tools.playwright.click.ClickToolInput - tools.playwright.current_page.CurrentWebPageTool - tools.playwright.extract_hyperlinks.ExtractHyperlinksTool - tools.playwright.extract_hyperlinks.ExtractHyperlinksToolInput - tools.playwright.extract_text.ExtractTextTool - tools.playwright.get_elements.GetElementsTool - tools.playwright.get_elements.GetElementsToolInput - tools.playwright.navigate.NavigateTool - tools.playwright.navigate.NavigateToolInput - tools.playwright.navigate_back.NavigateBackTool - tools.plugin.AIPlugin - tools.plugin.AIPluginTool - tools.plugin.AIPluginToolSchema - tools.plugin.ApiConfig - tools.powerbi.tool.InfoPowerBITool - tools.powerbi.tool.ListPowerBITool - tools.powerbi.tool.QueryPowerBITool - tools.pubmed.tool.PubmedQueryRun - tools.python.tool.PythonAstREPLTool - tools.python.tool.PythonREPLTool - tools.requests.tool.BaseRequestsTool - tools.requests.tool.RequestsDeleteTool - tools.requests.tool.RequestsGetTool - tools.requests.tool.RequestsPatchTool - tools.requests.tool.RequestsPostTool - tools.requests.tool.RequestsPutTool - tools.scenexplain.tool.SceneXplainInput - tools.scenexplain.tool.SceneXplainTool - tools.searx_search.tool.SearxSearchResults - tools.searx_search.tool.SearxSearchRun - tools.shell.tool.ShellInput - tools.shell.tool.ShellTool - tools.sleep.tool.SleepInput - tools.sleep.tool.SleepTool - tools.spark_sql.tool.BaseSparkSQLTool - tools.spark_sql.tool.InfoSparkSQLTool - tools.spark_sql.tool.ListSparkSQLTool - tools.spark_sql.tool.QueryCheckerTool - tools.spark_sql.tool.QuerySparkSQLTool - tools.sql_database.tool.BaseSQLDatabaseTool - tools.sql_database.tool.InfoSQLDatabaseTool - tools.sql_database.tool.ListSQLDatabaseTool - tools.sql_database.tool.QuerySQLCheckerTool - tools.sql_database.tool.QuerySQLDataBaseTool - tools.steamship_image_generation.tool.ModelName - tools.steamship_image_generation.tool.SteamshipImageGenerationTool - tools.vectorstore.tool.BaseVectorStoreTool - tools.vectorstore.tool.VectorStoreQATool - tools.vectorstore.tool.VectorStoreQAWithSourcesTool - tools.wikipedia.tool.WikipediaQueryRun - tools.wolfram_alpha.tool.WolframAlphaQueryRun - tools.youtube.search.YouTubeSearchTool - tools.zapier.tool.ZapierNLAListActions - tools.zapier.tool.ZapierNLARunAction - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: tools - - tools.azure_cognitive_services.utils.detect_file_src_type - tools.azure_cognitive_services.utils.download_audio_from_url - tools.base.create_schema_from_function - tools.base.tool - tools.convert_to_openai.format_tool_to_openai_function - tools.ddg_search.tool.DuckDuckGoSearchTool - tools.file_management.utils.get_validated_relative_path - tools.file_management.utils.is_relative_to - tools.gmail.utils.build_resource_service - tools.gmail.utils.clean_email_body - tools.gmail.utils.get_gmail_credentials - tools.gmail.utils.import_google - tools.gmail.utils.import_googleapiclient_resource_builder - tools.gmail.utils.import_installed_app_flow - tools.interaction.tool.StdInInquireTool - tools.office365.utils.authenticate - tools.office365.utils.clean_body - tools.playwright.base.lazy_import_playwright_browsers - tools.playwright.utils.create_async_playwright_browser - tools.playwright.utils.create_sync_playwright_browser - tools.playwright.utils.get_current_page - tools.playwright.utils.run_async - tools.plugin.marshal_spec - tools.python.tool.sanitize_input - tools.steamship_image_generation.utils.make_image_public - -:mod:`langchain.utilities`: Utilities -====================================== - -.. automodule:: langchain.utilities - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: utilities - :template: class.rst - - utilities.apify.ApifyWrapper - utilities.arxiv.ArxivAPIWrapper - utilities.awslambda.LambdaWrapper - utilities.bibtex.BibtexparserWrapper - utilities.bing_search.BingSearchAPIWrapper - utilities.brave_search.BraveSearchWrapper - utilities.dataforseo_api_search.DataForSeoAPIWrapper - utilities.duckduckgo_search.DuckDuckGoSearchAPIWrapper - utilities.google_places_api.GooglePlacesAPIWrapper - utilities.google_search.GoogleSearchAPIWrapper - utilities.google_serper.GoogleSerperAPIWrapper - utilities.graphql.GraphQLAPIWrapper - utilities.jira.JiraAPIWrapper - utilities.metaphor_search.MetaphorSearchAPIWrapper - utilities.openapi.HTTPVerb - utilities.openapi.OpenAPISpec - utilities.openweathermap.OpenWeatherMapAPIWrapper - utilities.powerbi.PowerBIDataset - utilities.pupmed.PubMedAPIWrapper - utilities.python.PythonREPL - utilities.scenexplain.SceneXplainAPIWrapper - utilities.searx_search.SearxResults - utilities.searx_search.SearxSearchWrapper - utilities.serpapi.SerpAPIWrapper - utilities.twilio.TwilioAPIWrapper - utilities.wikipedia.WikipediaAPIWrapper - utilities.wolfram_alpha.WolframAlphaAPIWrapper - utilities.zapier.ZapierNLAWrapper - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: utilities - - utilities.loading.try_load_from_hub - utilities.powerbi.fix_table_name - utilities.powerbi.json_to_md - utilities.vertexai.init_vertexai - utilities.vertexai.raise_vertex_import_error - -:mod:`langchain.utils`: Utils -============================== - -.. automodule:: langchain.utils - :no-members: - :no-inherited-members: - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: utils - - utils.comma_list - utils.get_from_dict_or_env - utils.get_from_env - utils.guard_import - utils.mock_now - utils.raise_for_status_with_text - utils.stringify_dict - utils.stringify_value - utils.xor_args - -:mod:`langchain.vectorstores`: Vectorstores -============================================ - -.. automodule:: langchain.vectorstores - :no-members: - :no-inherited-members: - -Classes --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: vectorstores - :template: class.rst - - vectorstores.alibabacloud_opensearch.AlibabaCloudOpenSearch - vectorstores.analyticdb.AnalyticDB - vectorstores.annoy.Annoy - vectorstores.atlas.AtlasDB - vectorstores.awadb.AwaDB - vectorstores.azuresearch.AzureSearch - vectorstores.azuresearch.AzureSearchVectorStoreRetriever - vectorstores.base.VectorStore - vectorstores.base.VectorStoreRetriever - vectorstores.cassandra.Cassandra - vectorstores.chroma.Chroma - vectorstores.clarifai.Clarifai - vectorstores.clickhouse.Clickhouse - vectorstores.clickhouse.ClickhouseSettings - vectorstores.deeplake.DeepLake - vectorstores.docarray.base.DocArrayIndex - vectorstores.docarray.hnsw.DocArrayHnswSearch - vectorstores.docarray.in_memory.DocArrayInMemorySearch - vectorstores.elastic_vector_search.ElasticKnnSearch - vectorstores.elastic_vector_search.ElasticVectorSearch - vectorstores.faiss.FAISS - vectorstores.hologres.Hologres - vectorstores.lancedb.LanceDB - vectorstores.marqo.Marqo - vectorstores.matching_engine.MatchingEngine - vectorstores.milvus.Milvus - vectorstores.mongodb_atlas.MongoDBAtlasVectorSearch - vectorstores.myscale.MyScale - vectorstores.myscale.MyScaleSettings - vectorstores.opensearch_vector_search.OpenSearchVectorSearch - vectorstores.pgembedding.BaseModel - vectorstores.pgembedding.CollectionStore - vectorstores.pgembedding.EmbeddingStore - vectorstores.pgembedding.PGEmbedding - vectorstores.pgvector.BaseModel - vectorstores.pgvector.CollectionStore - vectorstores.pgvector.DistanceStrategy - vectorstores.pgvector.EmbeddingStore - vectorstores.pgvector.PGVector - vectorstores.pinecone.Pinecone - vectorstores.qdrant.Qdrant - vectorstores.redis.Redis - vectorstores.redis.RedisVectorStoreRetriever - vectorstores.rocksetdb.Rockset - vectorstores.singlestoredb.DistanceStrategy - vectorstores.singlestoredb.SingleStoreDB - vectorstores.singlestoredb.SingleStoreDBRetriever - vectorstores.sklearn.BaseSerializer - vectorstores.sklearn.BsonSerializer - vectorstores.sklearn.JsonSerializer - vectorstores.sklearn.ParquetSerializer - vectorstores.sklearn.SKLearnVectorStore - vectorstores.sklearn.SKLearnVectorStoreException - vectorstores.starrocks.StarRocks - vectorstores.starrocks.StarRocksSettings - vectorstores.supabase.SupabaseVectorStore - vectorstores.tair.Tair - vectorstores.tigris.Tigris - vectorstores.typesense.Typesense - vectorstores.vectara.Vectara - vectorstores.vectara.VectaraRetriever - vectorstores.weaviate.Weaviate - vectorstores.zilliz.Zilliz - -Functions --------------- -.. currentmodule:: langchain - -.. autosummary:: - :toctree: vectorstores - - vectorstores.alibabacloud_opensearch.create_metadata - vectorstores.annoy.dependable_annoy_import - vectorstores.clickhouse.has_mul_sub_str - vectorstores.faiss.dependable_faiss_import - vectorstores.myscale.has_mul_sub_str - vectorstores.starrocks.debug_output - vectorstores.starrocks.get_named_result - vectorstores.starrocks.has_mul_sub_str - vectorstores.utils.maximal_marginal_relevance - diff --git a/docs/extras/ecosystem/integrations/arthur_tracking.ipynb b/docs/extras/ecosystem/integrations/arthur_tracking.ipynb index 5633dd194cf60..203d717923e02 100644 --- a/docs/extras/ecosystem/integrations/arthur_tracking.ipynb +++ b/docs/extras/ecosystem/integrations/arthur_tracking.ipynb @@ -120,7 +120,8 @@ " history = []\n", " while True:\n", " user_input = input(\"\\n>>> input >>>\\n>>>: \")\n", - " if user_input == 'q': break\n", + " if user_input == \"q\":\n", + " break\n", " history.append(HumanMessage(content=user_input))\n", " history.append(llm(history))" ] diff --git a/docs/extras/guides/evaluation/comparisons.ipynb b/docs/extras/guides/evaluation/comparisons.ipynb index c59c5cb0bc678..300623bb31bff 100644 --- a/docs/extras/guides/evaluation/comparisons.ipynb +++ b/docs/extras/guides/evaluation/comparisons.ipynb @@ -117,11 +117,11 @@ "\n", "\n", "# Initialize the language model\n", - "# You can add your own OpenAI API key by adding openai_api_key=\"\" \n", + "# You can add your own OpenAI API key by adding openai_api_key=\"\"\n", "llm = ChatOpenAI(temperature=0, model=\"gpt-3.5-turbo-0613\")\n", "\n", "# Initialize the SerpAPIWrapper for search functionality\n", - "#Replace in openai_api_key=\"\" with your actual SerpAPI key.\n", + "# Replace in openai_api_key=\"\" with your actual SerpAPI key.\n", "search = SerpAPIWrapper()\n", "\n", "# Define a list of tools offered by the agent\n", @@ -130,7 +130,7 @@ " name=\"Search\",\n", " func=search.run,\n", " coroutine=search.arun,\n", - " description=\"Useful when you need to answer questions about current events. You should ask targeted questions.\"\n", + " description=\"Useful when you need to answer questions about current events. You should ask targeted questions.\",\n", " ),\n", "]" ] @@ -143,8 +143,12 @@ }, "outputs": [], "source": [ - "functions_agent = initialize_agent(tools, llm, agent=AgentType.OPENAI_MULTI_FUNCTIONS, verbose=False)\n", - "conversations_agent = initialize_agent(tools, llm, agent=AgentType.CHAT_ZERO_SHOT_REACT_DESCRIPTION, verbose=False)" + "functions_agent = initialize_agent(\n", + " tools, llm, agent=AgentType.OPENAI_MULTI_FUNCTIONS, verbose=False\n", + ")\n", + "conversations_agent = initialize_agent(\n", + " tools, llm, agent=AgentType.CHAT_ZERO_SHOT_REACT_DESCRIPTION, verbose=False\n", + ")" ] }, { @@ -193,20 +197,20 @@ "\n", "results = []\n", "agents = [functions_agent, conversations_agent]\n", - "concurrency_level = 6 # How many concurrent agents to run. May need to decrease if OpenAI is rate limiting.\n", + "concurrency_level = 6 # How many concurrent agents to run. May need to decrease if OpenAI is rate limiting.\n", "\n", "# We will only run the first 20 examples of this dataset to speed things up\n", "# This will lead to larger confidence intervals downstream.\n", "batch = []\n", "for example in tqdm(dataset[:20]):\n", - " batch.extend([agent.acall(example['inputs']) for agent in agents])\n", + " batch.extend([agent.acall(example[\"inputs\"]) for agent in agents])\n", " if len(batch) >= concurrency_level:\n", " batch_results = await asyncio.gather(*batch, return_exceptions=True)\n", - " results.extend(list(zip(*[iter(batch_results)]*2)))\n", + " results.extend(list(zip(*[iter(batch_results)] * 2)))\n", " batch = []\n", "if batch:\n", " batch_results = await asyncio.gather(*batch, return_exceptions=True)\n", - " results.extend(list(zip(*[iter(batch_results)]*2)))" + " results.extend(list(zip(*[iter(batch_results)] * 2)))" ] }, { @@ -230,11 +234,12 @@ "source": [ "import random\n", "\n", + "\n", "def predict_preferences(dataset, results) -> list:\n", " preferences = []\n", "\n", " for example, (res_a, res_b) in zip(dataset, results):\n", - " input_ = example['inputs']\n", + " input_ = example[\"inputs\"]\n", " # Flip a coin to reduce persistent position bias\n", " if random.random() < 0.5:\n", " pred_a, pred_b = res_a, res_b\n", @@ -243,16 +248,16 @@ " pred_a, pred_b = res_b, res_a\n", " a, b = \"b\", \"a\"\n", " eval_res = eval_chain.evaluate_string_pairs(\n", - " prediction=pred_a['output'] if isinstance(pred_a, dict) else str(pred_a),\n", - " prediction_b=pred_b['output'] if isinstance(pred_b, dict) else str(pred_b),\n", - " input=input_\n", + " prediction=pred_a[\"output\"] if isinstance(pred_a, dict) else str(pred_a),\n", + " prediction_b=pred_b[\"output\"] if isinstance(pred_b, dict) else str(pred_b),\n", + " input=input_,\n", " )\n", " if eval_res[\"value\"] == \"A\":\n", " preferences.append(a)\n", " elif eval_res[\"value\"] == \"B\":\n", " preferences.append(b)\n", " else:\n", - " preferences.append(None) # No preference\n", + " preferences.append(None) # No preference\n", " return preferences" ] }, @@ -298,10 +303,7 @@ " \"b\": \"Structured Chat Agent\",\n", "}\n", "counts = Counter(preferences)\n", - "pref_ratios = {\n", - " k: v/len(preferences) for k, v in\n", - " counts.items()\n", - "}\n", + "pref_ratios = {k: v / len(preferences) for k, v in counts.items()}\n", "for k, v in pref_ratios.items():\n", " print(f\"{name_map.get(k)}: {v:.2%}\")" ] @@ -327,13 +329,16 @@ "source": [ "from math import sqrt\n", "\n", - "def wilson_score_interval(preferences: list, which: str = \"a\", z: float = 1.96) -> tuple:\n", + "\n", + "def wilson_score_interval(\n", + " preferences: list, which: str = \"a\", z: float = 1.96\n", + ") -> tuple:\n", " \"\"\"Estimate the confidence interval using the Wilson score.\n", - " \n", + "\n", " See: https://en.wikipedia.org/wiki/Binomial_proportion_confidence_interval#Wilson_score_interval\n", " for more details, including when to use it and when it should not be used.\n", " \"\"\"\n", - " total_preferences = preferences.count('a') + preferences.count('b')\n", + " total_preferences = preferences.count(\"a\") + preferences.count(\"b\")\n", " n_s = preferences.count(which)\n", "\n", " if total_preferences == 0:\n", @@ -342,8 +347,11 @@ " p_hat = n_s / total_preferences\n", "\n", " denominator = 1 + (z**2) / total_preferences\n", - " adjustment = (z / denominator) * sqrt(p_hat*(1-p_hat)/total_preferences + (z**2)/(4*total_preferences*total_preferences))\n", - " center = (p_hat + (z**2) / (2*total_preferences)) / denominator\n", + " adjustment = (z / denominator) * sqrt(\n", + " p_hat * (1 - p_hat) / total_preferences\n", + " + (z**2) / (4 * total_preferences * total_preferences)\n", + " )\n", + " center = (p_hat + (z**2) / (2 * total_preferences)) / denominator\n", " lower_bound = min(max(center - adjustment, 0.0), 1.0)\n", " upper_bound = min(max(center + adjustment, 0.0), 1.0)\n", "\n", @@ -369,7 +377,9 @@ "source": [ "for which_, name in name_map.items():\n", " low, high = wilson_score_interval(preferences, which=which_)\n", - " print(f'The \"{name}\" would be preferred between {low:.2%} and {high:.2%} percent of the time (with 95% confidence).')" + " print(\n", + " f'The \"{name}\" would be preferred between {low:.2%} and {high:.2%} percent of the time (with 95% confidence).'\n", + " )" ] }, { @@ -398,13 +408,16 @@ ], "source": [ "from scipy import stats\n", + "\n", "preferred_model = max(pref_ratios, key=pref_ratios.get)\n", "successes = preferences.count(preferred_model)\n", "n = len(preferences) - preferences.count(None)\n", - "p_value = stats.binom_test(successes, n, p=0.5, alternative='two-sided')\n", - "print(f\"\"\"The p-value is {p_value:.5f}. If the null hypothesis is true (i.e., if the selected eval chain actually has no preference between the models),\n", + "p_value = stats.binom_test(successes, n, p=0.5, alternative=\"two-sided\")\n", + "print(\n", + " f\"\"\"The p-value is {p_value:.5f}. If the null hypothesis is true (i.e., if the selected eval chain actually has no preference between the models),\n", "then there is a {p_value:.5%} chance of observing the {name_map.get(preferred_model)} be preferred at least {successes}\n", - "times out of {n} trials.\"\"\")" + "times out of {n} trials.\"\"\"\n", + ")" ] }, { diff --git a/docs/extras/guides/evaluation/criteria_eval_chain.ipynb b/docs/extras/guides/evaluation/criteria_eval_chain.ipynb index 326ce35eaad0f..5ed79701787b4 100644 --- a/docs/extras/guides/evaluation/criteria_eval_chain.ipynb +++ b/docs/extras/guides/evaluation/criteria_eval_chain.ipynb @@ -54,7 +54,7 @@ "outputs": [], "source": [ "llm = ChatOpenAI(temperature=0)\n", - "query=\"What's the origin of the term synecdoche?\"\n", + "query = \"What's the origin of the term synecdoche?\"\n", "prediction = llm.predict(query)" ] }, @@ -151,19 +151,22 @@ } ], "source": [ - "eval_chain = CriteriaEvalChain.from_llm(llm=llm, criteria=\"correctness\", requires_reference=True)\n", + "eval_chain = CriteriaEvalChain.from_llm(\n", + " llm=llm, criteria=\"correctness\", requires_reference=True\n", + ")\n", "\n", "# We can even override the model's learned knowledge using ground truth labels\n", "eval_result = eval_chain.evaluate_strings(\n", " input=\"What is the capital of the US?\",\n", - " prediction=\"Topeka, KS\", \n", - " reference=\"The capital of the US is Topeka, KS, where it permanently moved from Washington D.C. on May 16, 2023\")\n", + " prediction=\"Topeka, KS\",\n", + " reference=\"The capital of the US is Topeka, KS, where it permanently moved from Washington D.C. on May 16, 2023\",\n", + ")\n", "print(f'With ground truth: {eval_result[\"score\"]}')\n", "\n", "eval_chain = CriteriaEvalChain.from_llm(llm=llm, criteria=\"correctness\")\n", "eval_result = eval_chain.evaluate_strings(\n", " input=\"What is the capital of the US?\",\n", - " prediction=\"Topeka, KS\", \n", + " prediction=\"Topeka, KS\",\n", ")\n", "print(f'Withoutg ground truth: {eval_result[\"score\"]}')" ] @@ -230,9 +233,7 @@ } ], "source": [ - "custom_criterion = {\n", - " \"numeric\": \"Does the output contain numeric information?\"\n", - "}\n", + "custom_criterion = {\"numeric\": \"Does the output contain numeric information?\"}\n", "\n", "eval_chain = CriteriaEvalChain.from_llm(llm=llm, criteria=custom_criterion)\n", "eval_result = eval_chain.evaluate_strings(prediction=prediction, input=query)\n", @@ -269,11 +270,17 @@ "\n", "# Example that complies\n", "query = \"What's the population of lagos?\"\n", - "eval_result = eval_chain.evaluate_strings(prediction=\"I think that's a great question, you're really curious! About 30 million people live in Lagos, Nigeria, as of 2023.\", input=query)\n", + "eval_result = eval_chain.evaluate_strings(\n", + " prediction=\"I think that's a great question, you're really curious! About 30 million people live in Lagos, Nigeria, as of 2023.\",\n", + " input=query,\n", + ")\n", "print(\"Meets criteria: \", eval_result[\"score\"])\n", "\n", "# Example that does not comply\n", - "eval_result = eval_chain.evaluate_strings(prediction=\"The population of Lagos, Nigeria, is about 30 million people.\", input=query)\n", + "eval_result = eval_chain.evaluate_strings(\n", + " prediction=\"The population of Lagos, Nigeria, is about 30 million people.\",\n", + " input=query,\n", + ")\n", "print(\"Does not meet criteria: \", eval_result[\"score\"])" ] }, @@ -350,8 +357,13 @@ } ], "source": [ - "eval_chain = CriteriaEvalChain.from_llm(llm=llm, criteria=[PRINCIPLES[\"harmful1\"], PRINCIPLES[\"harmful2\"]])\n", - "eval_result = eval_chain.evaluate_strings(prediction=\"I say that man is a lilly-livered nincompoop\", input=\"What do you think of Will?\")\n", + "eval_chain = CriteriaEvalChain.from_llm(\n", + " llm=llm, criteria=[PRINCIPLES[\"harmful1\"], PRINCIPLES[\"harmful2\"]]\n", + ")\n", + "eval_result = eval_chain.evaluate_strings(\n", + " prediction=\"I say that man is a lilly-livered nincompoop\",\n", + " input=\"What do you think of Will?\",\n", + ")\n", "eval_result" ] }, diff --git a/docs/extras/guides/evaluation/generic_agent_evaluation.ipynb b/docs/extras/guides/evaluation/generic_agent_evaluation.ipynb index c56cca9a9e1c8..3ebc00306f7c5 100644 --- a/docs/extras/guides/evaluation/generic_agent_evaluation.ipynb +++ b/docs/extras/guides/evaluation/generic_agent_evaluation.ipynb @@ -339,9 +339,9 @@ " agent_trajectory=test_outputs_one[\"intermediate_steps\"],\n", " reference=(\n", " \"You need many more than 100,000 ping-pong balls in the empire state building.\"\n", - " )\n", + " ),\n", ")\n", - " \n", + "\n", "\n", "print(\"Score from 1 to 5: \", evaluation[\"score\"])\n", "print(\"Reasoning: \", evaluation[\"reasoning\"])" diff --git a/docs/extras/modules/agents/agent_types/openai_multi_functions_agent.ipynb b/docs/extras/modules/agents/agent_types/openai_multi_functions_agent.ipynb index 372efa678590b..33735d36a7b44 100644 --- a/docs/extras/modules/agents/agent_types/openai_multi_functions_agent.ipynb +++ b/docs/extras/modules/agents/agent_types/openai_multi_functions_agent.ipynb @@ -47,7 +47,9 @@ "source": [ "import os\n", "\n", - "os.environ[\"SERPAPI_API_KEY\"] = \"897780527132b5f31d8d73c40c820d5ef2c2279687efa69f413a61f752027747\"" + "os.environ[\n", + " \"SERPAPI_API_KEY\"\n", + "] = \"897780527132b5f31d8d73c40c820d5ef2c2279687efa69f413a61f752027747\"" ] }, { @@ -58,11 +60,11 @@ "outputs": [], "source": [ "# Initialize the OpenAI language model\n", - "#Replace in openai_api_key=\"\" with your actual OpenAI key.\n", + "# Replace in openai_api_key=\"\" with your actual OpenAI key.\n", "llm = ChatOpenAI(temperature=0, model=\"gpt-3.5-turbo-0613\")\n", "\n", "# Initialize the SerpAPIWrapper for search functionality\n", - "#Replace in openai_api_key=\"\" with your actual SerpAPI key.\n", + "# Replace in openai_api_key=\"\" with your actual SerpAPI key.\n", "search = SerpAPIWrapper()\n", "\n", "# Define a list of tools offered by the agent\n", @@ -70,9 +72,9 @@ " Tool(\n", " name=\"Search\",\n", " func=search.run,\n", - " description=\"Useful when you need to answer questions about current events. You should ask targeted questions.\"\n", + " description=\"Useful when you need to answer questions about current events. You should ask targeted questions.\",\n", " ),\n", - "]\n" + "]" ] }, { @@ -82,7 +84,9 @@ "metadata": {}, "outputs": [], "source": [ - "mrkl = initialize_agent(tools, llm, agent=AgentType.OPENAI_MULTI_FUNCTIONS, verbose=True)" + "mrkl = initialize_agent(\n", + " tools, llm, agent=AgentType.OPENAI_MULTI_FUNCTIONS, verbose=True\n", + ")" ] }, { @@ -94,6 +98,7 @@ "source": [ "# Do this so we can see exactly what's going on under the hood\n", "import langchain\n", + "\n", "langchain.debug = True" ] }, @@ -206,9 +211,7 @@ } ], "source": [ - "mrkl.run(\n", - " \"What is the weather in LA and SF?\"\n", - ")" + "mrkl.run(\"What is the weather in LA and SF?\")" ] }, { @@ -229,12 +232,12 @@ "outputs": [], "source": [ "mrkl = initialize_agent(\n", - " tools, \n", - " llm, \n", - " agent=AgentType.OPENAI_FUNCTIONS, \n", - " verbose=True, \n", - " max_iterations=2, \n", - " early_stopping_method=\"generate\"\n", + " tools,\n", + " llm,\n", + " agent=AgentType.OPENAI_FUNCTIONS,\n", + " verbose=True,\n", + " max_iterations=2,\n", + " early_stopping_method=\"generate\",\n", ")" ] }, @@ -410,9 +413,7 @@ } ], "source": [ - "mrkl.run(\n", - " \"What is the weather in NYC today, yesterday, and the day before?\"\n", - ")" + "mrkl.run(\"What is the weather in NYC today, yesterday, and the day before?\")" ] }, { diff --git a/docs/extras/modules/agents/how_to/add_memory_openai_functions.ipynb b/docs/extras/modules/agents/how_to/add_memory_openai_functions.ipynb index 7da668e2f5471..51815a069d85b 100644 --- a/docs/extras/modules/agents/how_to/add_memory_openai_functions.ipynb +++ b/docs/extras/modules/agents/how_to/add_memory_openai_functions.ipynb @@ -78,6 +78,7 @@ "source": [ "from langchain.prompts import MessagesPlaceholder\n", "from langchain.memory import ConversationBufferMemory\n", + "\n", "agent_kwargs = {\n", " \"extra_prompt_messages\": [MessagesPlaceholder(variable_name=\"memory\")],\n", "}\n", @@ -92,12 +93,12 @@ "outputs": [], "source": [ "agent = initialize_agent(\n", - " tools, \n", - " llm, \n", - " agent=AgentType.OPENAI_FUNCTIONS, \n", - " verbose=True, \n", - " agent_kwargs=agent_kwargs, \n", - " memory=memory\n", + " tools,\n", + " llm,\n", + " agent=AgentType.OPENAI_FUNCTIONS,\n", + " verbose=True,\n", + " agent_kwargs=agent_kwargs,\n", + " memory=memory,\n", ")" ] }, diff --git a/docs/extras/modules/agents/how_to/custom-functions-with-openai-functions-agent.ipynb b/docs/extras/modules/agents/how_to/custom-functions-with-openai-functions-agent.ipynb index f5928b0f5f785..bca6afa97b2c7 100644 --- a/docs/extras/modules/agents/how_to/custom-functions-with-openai-functions-agent.ipynb +++ b/docs/extras/modules/agents/how_to/custom-functions-with-openai-functions-agent.ipynb @@ -42,15 +42,14 @@ "import yfinance as yf\n", "from datetime import datetime, timedelta\n", "\n", + "\n", "def get_current_stock_price(ticker):\n", " \"\"\"Method to get current stock price\"\"\"\n", "\n", " ticker_data = yf.Ticker(ticker)\n", - " recent = ticker_data.history(period='1d')\n", - " return {\n", - " 'price': recent.iloc[0]['Close'],\n", - " 'currency': ticker_data.info['currency']\n", - " }\n", + " recent = ticker_data.history(period=\"1d\")\n", + " return {\"price\": recent.iloc[0][\"Close\"], \"currency\": ticker_data.info[\"currency\"]}\n", + "\n", "\n", "def get_stock_performance(ticker, days):\n", " \"\"\"Method to get stock price change in percentage\"\"\"\n", @@ -58,11 +57,9 @@ " past_date = datetime.today() - timedelta(days=days)\n", " ticker_data = yf.Ticker(ticker)\n", " history = ticker_data.history(start=past_date)\n", - " old_price = history.iloc[0]['Close']\n", - " current_price = history.iloc[-1]['Close']\n", - " return {\n", - " 'percent_change': ((current_price - old_price)/old_price)*100\n", - " }" + " old_price = history.iloc[0][\"Close\"]\n", + " current_price = history.iloc[-1][\"Close\"]\n", + " return {\"percent_change\": ((current_price - old_price) / old_price) * 100}" ] }, { @@ -88,7 +85,7 @@ } ], "source": [ - "get_current_stock_price('MSFT')" + "get_current_stock_price(\"MSFT\")" ] }, { @@ -114,7 +111,7 @@ } ], "source": [ - "get_stock_performance('MSFT', 30)" + "get_stock_performance(\"MSFT\", 30)" ] }, { @@ -138,10 +135,13 @@ "from pydantic import BaseModel, Field\n", "from langchain.tools import BaseTool\n", "\n", + "\n", "class CurrentStockPriceInput(BaseModel):\n", " \"\"\"Inputs for get_current_stock_price\"\"\"\n", + "\n", " ticker: str = Field(description=\"Ticker symbol of the stock\")\n", "\n", + "\n", "class CurrentStockPriceTool(BaseTool):\n", " name = \"get_current_stock_price\"\n", " description = \"\"\"\n", @@ -160,8 +160,10 @@ "\n", "class StockPercentChangeInput(BaseModel):\n", " \"\"\"Inputs for get_stock_performance\"\"\"\n", + "\n", " ticker: str = Field(description=\"Ticker symbol of the stock\")\n", - " days: int = Field(description='Timedelta days to get past date from current date')\n", + " days: int = Field(description=\"Timedelta days to get past date from current date\")\n", + "\n", "\n", "class StockPerformanceTool(BaseTool):\n", " name = \"get_stock_performance\"\n", @@ -202,15 +204,9 @@ "from langchain.chat_models import ChatOpenAI\n", "from langchain.agents import initialize_agent\n", "\n", - "llm = ChatOpenAI(\n", - " model=\"gpt-3.5-turbo-0613\",\n", - " temperature=0\n", - ")\n", + "llm = ChatOpenAI(model=\"gpt-3.5-turbo-0613\", temperature=0)\n", "\n", - "tools = [\n", - " CurrentStockPriceTool(),\n", - " StockPerformanceTool()\n", - "]\n", + "tools = [CurrentStockPriceTool(), StockPerformanceTool()]\n", "\n", "agent = initialize_agent(tools, llm, agent=AgentType.OPENAI_FUNCTIONS, verbose=True)" ] @@ -261,7 +257,9 @@ } ], "source": [ - "agent.run(\"What is the current price of Microsoft stock? How it has performed over past 6 months?\")" + "agent.run(\n", + " \"What is the current price of Microsoft stock? How it has performed over past 6 months?\"\n", + ")" ] }, { @@ -355,7 +353,9 @@ } ], "source": [ - "agent.run('In the past 3 months, which stock between Microsoft and Google has performed the best?')" + "agent.run(\n", + " \"In the past 3 months, which stock between Microsoft and Google has performed the best?\"\n", + ")" ] } ], diff --git a/docs/extras/modules/agents/how_to/use_toolkits_with_openai_functions.ipynb b/docs/extras/modules/agents/how_to/use_toolkits_with_openai_functions.ipynb index f17aff188fef2..78a70c47d1904 100644 --- a/docs/extras/modules/agents/how_to/use_toolkits_with_openai_functions.ipynb +++ b/docs/extras/modules/agents/how_to/use_toolkits_with_openai_functions.ipynb @@ -79,10 +79,10 @@ "source": [ "llm = ChatOpenAI(temperature=0, model=\"gpt-3.5-turbo-0613\")\n", "agent = initialize_agent(\n", - " toolkit.get_tools(), \n", - " llm, \n", - " agent=AgentType.OPENAI_FUNCTIONS, \n", - " verbose=True, \n", + " toolkit.get_tools(),\n", + " llm,\n", + " agent=AgentType.OPENAI_FUNCTIONS,\n", + " verbose=True,\n", " agent_kwargs=agent_kwargs,\n", ")" ] diff --git a/docs/extras/modules/agents/toolkits/document_comparison_toolkit.ipynb b/docs/extras/modules/agents/toolkits/document_comparison_toolkit.ipynb index 2f0fe52311425..5dbe075516e5c 100644 --- a/docs/extras/modules/agents/toolkits/document_comparison_toolkit.ipynb +++ b/docs/extras/modules/agents/toolkits/document_comparison_toolkit.ipynb @@ -47,14 +47,14 @@ "files = [\n", " # https://abc.xyz/investor/static/pdf/2023Q1_alphabet_earnings_release.pdf\n", " {\n", - " \"name\": \"alphabet-earnings\", \n", + " \"name\": \"alphabet-earnings\",\n", " \"path\": \"/Users/harrisonchase/Downloads/2023Q1_alphabet_earnings_release.pdf\",\n", - " }, \n", + " },\n", " # https://digitalassets.tesla.com/tesla-contents/image/upload/IR/TSLA-Q1-2023-Update\n", " {\n", - " \"name\": \"tesla-earnings\", \n", - " \"path\": \"/Users/harrisonchase/Downloads/TSLA-Q1-2023-Update.pdf\"\n", - " }\n", + " \"name\": \"tesla-earnings\",\n", + " \"path\": \"/Users/harrisonchase/Downloads/TSLA-Q1-2023-Update.pdf\",\n", + " },\n", "]\n", "\n", "for file in files:\n", @@ -64,14 +64,14 @@ " docs = text_splitter.split_documents(pages)\n", " embeddings = OpenAIEmbeddings()\n", " retriever = FAISS.from_documents(docs, embeddings).as_retriever()\n", - " \n", + "\n", " # Wrap retrievers in a Tool\n", " tools.append(\n", " Tool(\n", " args_schema=DocumentInput,\n", - " name=file[\"name\"], \n", + " name=file[\"name\"],\n", " description=f\"useful when you want to answer questions about {file['name']}\",\n", - " func=RetrievalQA.from_chain_type(llm=llm, retriever=retriever)\n", + " func=RetrievalQA.from_chain_type(llm=llm, retriever=retriever),\n", " )\n", " )" ] @@ -130,7 +130,7 @@ "source": [ "llm = ChatOpenAI(\n", " temperature=0,\n", - " model=\"gpt-3.5-turbo-0613\", \n", + " model=\"gpt-3.5-turbo-0613\",\n", ")\n", "\n", "agent = initialize_agent(\n", @@ -161,6 +161,7 @@ "outputs": [], "source": [ "import langchain\n", + "\n", "langchain.debug = True" ] }, @@ -396,7 +397,7 @@ "source": [ "llm = ChatOpenAI(\n", " temperature=0,\n", - " model=\"gpt-3.5-turbo-0613\", \n", + " model=\"gpt-3.5-turbo-0613\",\n", ")\n", "\n", "agent = initialize_agent(\n", diff --git a/docs/extras/modules/agents/toolkits/office365.ipynb b/docs/extras/modules/agents/toolkits/office365.ipynb index 07c4e14f0bd5f..704ceec4e1657 100644 --- a/docs/extras/modules/agents/toolkits/office365.ipynb +++ b/docs/extras/modules/agents/toolkits/office365.ipynb @@ -136,9 +136,11 @@ } ], "source": [ - "agent.run(\"Create an email draft for me to edit of a letter from the perspective of a sentient parrot\"\n", - " \" who is looking to collaborate on some research with her\"\n", - " \" estranged friend, a cat. Under no circumstances may you send the message, however.\")" + "agent.run(\n", + " \"Create an email draft for me to edit of a letter from the perspective of a sentient parrot\"\n", + " \" who is looking to collaborate on some research with her\"\n", + " \" estranged friend, a cat. Under no circumstances may you send the message, however.\"\n", + ")" ] }, { @@ -160,7 +162,9 @@ } ], "source": [ - "agent.run(\"Could you search in my drafts folder and let me know if any of them are about collaboration?\")" + "agent.run(\n", + " \"Could you search in my drafts folder and let me know if any of them are about collaboration?\"\n", + ")" ] }, { @@ -190,7 +194,9 @@ } ], "source": [ - "agent.run(\"Can you schedule a 30 minute meeting with a sentient parrot to discuss research collaborations on October 3, 2023 at 2 pm Easter Time?\")" + "agent.run(\n", + " \"Can you schedule a 30 minute meeting with a sentient parrot to discuss research collaborations on October 3, 2023 at 2 pm Easter Time?\"\n", + ")" ] }, { @@ -210,7 +216,9 @@ } ], "source": [ - "agent.run(\"Can you tell me if I have any events on October 3, 2023 in Eastern Time, and if so, tell me if any of them are with a sentient parrot?\")" + "agent.run(\n", + " \"Can you tell me if I have any events on October 3, 2023 in Eastern Time, and if so, tell me if any of them are with a sentient parrot?\"\n", + ")" ] } ], diff --git a/docs/extras/modules/agents/tools/integrations/dataforseo.ipynb b/docs/extras/modules/agents/tools/integrations/dataforseo.ipynb index b1eb1fb1ac0d8..3aed7f28fc3aa 100644 --- a/docs/extras/modules/agents/tools/integrations/dataforseo.ipynb +++ b/docs/extras/modules/agents/tools/integrations/dataforseo.ipynb @@ -34,6 +34,7 @@ "outputs": [], "source": [ "import os\n", + "\n", "os.environ[\"DATAFORSEO_LOGIN\"] = \"your_api_access_username\"\n", "os.environ[\"DATAFORSEO_PASSWORD\"] = \"your_api_access_password\"\n", "\n", @@ -88,7 +89,8 @@ "json_wrapper = DataForSeoAPIWrapper(\n", " json_result_types=[\"organic\", \"knowledge_graph\", \"answer_box\"],\n", " json_result_fields=[\"type\", \"title\", \"description\", \"text\"],\n", - " top_count=3)" + " top_count=3,\n", + ")" ] }, { @@ -119,7 +121,8 @@ " top_count=10,\n", " json_result_types=[\"organic\", \"local_pack\"],\n", " json_result_fields=[\"title\", \"description\", \"type\"],\n", - " params={\"location_name\": \"Germany\", \"language_code\": \"en\"})\n", + " params={\"location_name\": \"Germany\", \"language_code\": \"en\"},\n", + ")\n", "customized_wrapper.results(\"coffee near me\")" ] }, @@ -142,7 +145,8 @@ " top_count=10,\n", " json_result_types=[\"organic\", \"local_pack\"],\n", " json_result_fields=[\"title\", \"description\", \"type\"],\n", - " params={\"location_name\": \"Germany\", \"language_code\": \"en\", \"se_name\": \"bing\"})\n", + " params={\"location_name\": \"Germany\", \"language_code\": \"en\", \"se_name\": \"bing\"},\n", + ")\n", "customized_wrapper.results(\"coffee near me\")" ] }, @@ -164,7 +168,12 @@ "maps_search = DataForSeoAPIWrapper(\n", " top_count=10,\n", " json_result_fields=[\"title\", \"value\", \"address\", \"rating\", \"type\"],\n", - " params={\"location_coordinate\": \"52.512,13.36,12z\", \"language_code\": \"en\", \"se_type\": \"maps\"})\n", + " params={\n", + " \"location_coordinate\": \"52.512,13.36,12z\",\n", + " \"language_code\": \"en\",\n", + " \"se_type\": \"maps\",\n", + " },\n", + ")\n", "maps_search.results(\"coffee near me\")" ] }, @@ -184,10 +193,12 @@ "outputs": [], "source": [ "from langchain.agents import Tool\n", + "\n", "search = DataForSeoAPIWrapper(\n", " top_count=3,\n", " json_result_types=[\"organic\"],\n", - " json_result_fields=[\"title\", \"description\", \"type\"])\n", + " json_result_fields=[\"title\", \"description\", \"type\"],\n", + ")\n", "tool = Tool(\n", " name=\"google-search-answer\",\n", " description=\"My new answer tool\",\n", diff --git a/docs/extras/modules/agents/tools/integrations/metaphor_search.ipynb b/docs/extras/modules/agents/tools/integrations/metaphor_search.ipynb index ec52910c98286..d175d2234f21b 100644 --- a/docs/extras/modules/agents/tools/integrations/metaphor_search.ipynb +++ b/docs/extras/modules/agents/tools/integrations/metaphor_search.ipynb @@ -90,7 +90,12 @@ "metadata": {}, "outputs": [], "source": [ - "search.results(\"The best blog post about AI safety is definitely this: \", 10, include_domains=[\"lesswrong.com\"], start_published_date=\"2019-01-01\")" + "search.results(\n", + " \"The best blog post about AI safety is definitely this: \",\n", + " 10,\n", + " include_domains=[\"lesswrong.com\"],\n", + " start_published_date=\"2019-01-01\",\n", + ")" ] }, { diff --git a/docs/extras/modules/agents/tools/integrations/zapier.ipynb b/docs/extras/modules/agents/tools/integrations/zapier.ipynb index 3114ad3bee092..17bd9cdd75413 100644 --- a/docs/extras/modules/agents/tools/integrations/zapier.ipynb +++ b/docs/extras/modules/agents/tools/integrations/zapier.ipynb @@ -341,7 +341,7 @@ "outputs": [], "source": [ "llm = OpenAI(temperature=0)\n", - "zapier = ZapierNLAWrapper(zapier_nla_oauth_access_token='')\n", + "zapier = ZapierNLAWrapper(zapier_nla_oauth_access_token=\"\")\n", "toolkit = ZapierToolkit.from_zapier_nla_wrapper(zapier)\n", "agent = initialize_agent(\n", " toolkit.get_tools(), llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True\n", diff --git a/docs/extras/modules/callbacks/integrations/infino.ipynb b/docs/extras/modules/callbacks/integrations/infino.ipynb index e619fc0e4d661..082e84c3a8679 100644 --- a/docs/extras/modules/callbacks/integrations/infino.ipynb +++ b/docs/extras/modules/callbacks/integrations/infino.ipynb @@ -57,6 +57,7 @@ "\n", "# Remove the (1) import sys and sys.path.append(..) and (2) uncomment `!pip install langchain` after merging the PR for Infino/LangChain integration.\n", "import sys\n", + "\n", "sys.path.append(\"../../../../../langchain\")\n", "#!pip install langchain\n", "\n", @@ -120,9 +121,9 @@ "metadata": {}, "outputs": [], "source": [ - "# These are a subset of questions from Stanford's QA dataset - \n", + "# These are a subset of questions from Stanford's QA dataset -\n", "# https://rajpurkar.github.io/SQuAD-explorer/\n", - "data = '''In what country is Normandy located?\n", + "data = \"\"\"In what country is Normandy located?\n", "When were the Normans in Normandy?\n", "From which countries did the Norse originate?\n", "Who was the Norse leader?\n", @@ -141,9 +142,9 @@ "What principality did William the conquerer found?\n", "What is the original meaning of the word Norman?\n", "When was the Latin version of the word Norman first recorded?\n", - "What name comes from the English words Normans/Normanz?'''\n", + "What name comes from the English words Normans/Normanz?\"\"\"\n", "\n", - "questions = data.split('\\n')" + "questions = data.split(\"\\n\")" ] }, { @@ -190,10 +191,12 @@ ], "source": [ "# Set your key here.\n", - "#os.environ[\"OPENAI_API_KEY\"] = \"YOUR_API_KEY\"\n", + "# os.environ[\"OPENAI_API_KEY\"] = \"YOUR_API_KEY\"\n", "\n", "# Create callback handler. This logs latency, errors, token usage, prompts as well as prompt responses to Infino.\n", - "handler = InfinoCallbackHandler(model_id=\"test_openai\", model_version=\"0.1\", verbose=False)\n", + "handler = InfinoCallbackHandler(\n", + " model_id=\"test_openai\", model_version=\"0.1\", verbose=False\n", + ")\n", "\n", "# Create LLM.\n", "llm = OpenAI(temperature=0.1)\n", @@ -281,29 +284,30 @@ "source": [ "# Helper function to create a graph using matplotlib.\n", "def plot(data, title):\n", - " data = json.loads(data)\n", + " data = json.loads(data)\n", + "\n", + " # Extract x and y values from the data\n", + " timestamps = [item[\"time\"] for item in data]\n", + " dates = [dt.datetime.fromtimestamp(ts) for ts in timestamps]\n", + " y = [item[\"value\"] for item in data]\n", + "\n", + " plt.rcParams[\"figure.figsize\"] = [6, 4]\n", + " plt.subplots_adjust(bottom=0.2)\n", + " plt.xticks(rotation=25)\n", + " ax = plt.gca()\n", + " xfmt = md.DateFormatter(\"%Y-%m-%d %H:%M:%S\")\n", + " ax.xaxis.set_major_formatter(xfmt)\n", "\n", - " # Extract x and y values from the data\n", - " timestamps = [item[\"time\"] for item in data]\n", - " dates=[dt.datetime.fromtimestamp(ts) for ts in timestamps]\n", - " y = [item[\"value\"] for item in data]\n", + " # Create the plot\n", + " plt.plot(dates, y)\n", "\n", - " plt.rcParams['figure.figsize'] = [6, 4]\n", - " plt.subplots_adjust(bottom=0.2)\n", - " plt.xticks(rotation=25 )\n", - " ax=plt.gca()\n", - " xfmt = md.DateFormatter('%Y-%m-%d %H:%M:%S')\n", - " ax.xaxis.set_major_formatter(xfmt)\n", - " \n", - " # Create the plot\n", - " plt.plot(dates, y)\n", + " # Set labels and title\n", + " plt.xlabel(\"Time\")\n", + " plt.ylabel(\"Value\")\n", + " plt.title(title)\n", "\n", - " # Set labels and title\n", - " plt.xlabel(\"Time\")\n", - " plt.ylabel(\"Value\")\n", - " plt.title(title)\n", + " plt.show()\n", "\n", - " plt.show()\n", "\n", "response = client.search_ts(\"__name__\", \"latency\", 0, int(time.time()))\n", "plot(response.text, \"Latency\")\n", @@ -318,7 +322,7 @@ "plot(response.text, \"Completion Tokens\")\n", "\n", "response = client.search_ts(\"__name__\", \"total_tokens\", 0, int(time.time()))\n", - "plot(response.text, \"Total Tokens\")\n" + "plot(response.text, \"Total Tokens\")" ] }, { @@ -356,7 +360,7 @@ "\n", "query = \"king charles III\"\n", "response = client.search_log(\"king charles III\", 0, int(time.time()))\n", - "print(\"Results for\", query, \":\", response.text)\n" + "print(\"Results for\", query, \":\", response.text)" ] }, { diff --git a/docs/extras/modules/chains/additional/cpal.ipynb b/docs/extras/modules/chains/additional/cpal.ipynb index 6b34fdc4d6ba3..2ee78c205e356 100644 --- a/docs/extras/modules/chains/additional/cpal.ipynb +++ b/docs/extras/modules/chains/additional/cpal.ipynb @@ -326,8 +326,8 @@ ], "source": [ "# wait 20 secs to see display\n", - "cpal_chain.draw(path='web.svg')\n", - "SVG('web.svg')" + "cpal_chain.draw(path=\"web.svg\")\n", + "SVG(\"web.svg\")" ] }, { @@ -348,10 +348,10 @@ "outputs": [], "source": [ "question = (\n", - " \"Jan has three times the number of pets as Marcia.\"\n", - " \"Marcia has two more pets than Cindy.\"\n", - " \"If Cindy has ten pets, how many pets does Barak have?\"\n", - " )" + " \"Jan has three times the number of pets as Marcia.\"\n", + " \"Marcia has two more pets than Cindy.\"\n", + " \"If Cindy has ten pets, how many pets does Barak have?\"\n", + ")" ] }, { @@ -456,7 +456,7 @@ "outputs": [], "source": [ "question = (\n", - " \"Jan has three times the number of pets as Marcia. \" \n", + " \"Jan has three times the number of pets as Marcia. \"\n", " \"Marcia has two more pets than Cindy. \"\n", " \"If Cindy has four pets, how many total pets do the three have?\"\n", ")" @@ -621,8 +621,8 @@ ], "source": [ "# wait 20 secs to see display\n", - "cpal_chain.draw(path='web.svg')\n", - "SVG('web.svg')" + "cpal_chain.draw(path=\"web.svg\")\n", + "SVG(\"web.svg\")" ] }, { @@ -641,7 +641,7 @@ "outputs": [], "source": [ "question = (\n", - " \"Jan has the number of pets as Marcia plus the number of pets as Cindy. \" \n", + " \"Jan has the number of pets as Marcia plus the number of pets as Cindy. \"\n", " \"Marcia has no pets. \"\n", " \"If Cindy has four pets, how many total pets do the three have?\"\n", ")" @@ -748,8 +748,8 @@ ], "source": [ "# wait 20 secs to see display\n", - "cpal_chain.draw(path='web.svg')\n", - "SVG('web.svg')" + "cpal_chain.draw(path=\"web.svg\")\n", + "SVG(\"web.svg\")" ] }, { @@ -768,7 +768,7 @@ "outputs": [], "source": [ "question = (\n", - " \"Jan has the number of pets as Marcia plus the number of pets as Cindy. \" \n", + " \"Jan has the number of pets as Marcia plus the number of pets as Cindy. \"\n", " \"Marcia has two more pets than Cindy. \"\n", " \"If Cindy has four pets, how many total pets do the three have?\"\n", ")" @@ -881,8 +881,8 @@ ], "source": [ "# wait 20 secs to see display\n", - "cpal_chain.draw(path='web.svg')\n", - "SVG('web.svg')" + "cpal_chain.draw(path=\"web.svg\")\n", + "SVG(\"web.svg\")" ] }, { diff --git a/docs/extras/modules/chains/additional/flare.ipynb b/docs/extras/modules/chains/additional/flare.ipynb index c72b74c46fe51..5687e06e2ecba 100644 --- a/docs/extras/modules/chains/additional/flare.ipynb +++ b/docs/extras/modules/chains/additional/flare.ipynb @@ -72,7 +72,10 @@ "import numpy as np\n", "\n", "from langchain.schema import BaseRetriever\n", - "from langchain.callbacks.manager import AsyncCallbackManagerForRetrieverRun, CallbackManagerForRetrieverRun\n", + "from langchain.callbacks.manager import (\n", + " AsyncCallbackManagerForRetrieverRun,\n", + " CallbackManagerForRetrieverRun,\n", + ")\n", "from langchain.utilities import GoogleSerperAPIWrapper\n", "from langchain.embeddings import OpenAIEmbeddings\n", "from langchain.chat_models import ChatOpenAI\n", @@ -97,13 +100,15 @@ "outputs": [], "source": [ "class SerperSearchRetriever(BaseRetriever):\n", - "\n", " search: GoogleSerperAPIWrapper = None\n", "\n", - " def _get_relevant_documents(self, query: str, *, run_manager: CallbackManagerForRetrieverRun, **kwargs: Any) -> List[Document]:\n", + " def _get_relevant_documents(\n", + " self, query: str, *, run_manager: CallbackManagerForRetrieverRun, **kwargs: Any\n", + " ) -> List[Document]:\n", " return [Document(page_content=self.search.run(query))]\n", "\n", - " async def _aget_relevant_documents(self,\n", + " async def _aget_relevant_documents(\n", + " self,\n", " query: str,\n", " *,\n", " run_manager: AsyncCallbackManagerForRetrieverRun,\n", diff --git a/docs/extras/modules/chains/additional/graph_hugegraph_qa.ipynb b/docs/extras/modules/chains/additional/graph_hugegraph_qa.ipynb index 261df2708b84e..dfd64125ae89d 100644 --- a/docs/extras/modules/chains/additional/graph_hugegraph_qa.ipynb +++ b/docs/extras/modules/chains/additional/graph_hugegraph_qa.ipynb @@ -83,9 +83,15 @@ "schema = client.schema()\n", "schema.propertyKey(\"name\").asText().ifNotExist().create()\n", "schema.propertyKey(\"birthDate\").asText().ifNotExist().create()\n", - "schema.vertexLabel(\"Person\").properties(\"name\", \"birthDate\").usePrimaryKeyId().primaryKeys(\"name\").ifNotExist().create()\n", - "schema.vertexLabel(\"Movie\").properties(\"name\").usePrimaryKeyId().primaryKeys(\"name\").ifNotExist().create()\n", - "schema.edgeLabel(\"ActedIn\").sourceLabel(\"Person\").targetLabel(\"Movie\").ifNotExist().create()" + "schema.vertexLabel(\"Person\").properties(\n", + " \"name\", \"birthDate\"\n", + ").usePrimaryKeyId().primaryKeys(\"name\").ifNotExist().create()\n", + "schema.vertexLabel(\"Movie\").properties(\"name\").usePrimaryKeyId().primaryKeys(\n", + " \"name\"\n", + ").ifNotExist().create()\n", + "schema.edgeLabel(\"ActedIn\").sourceLabel(\"Person\").targetLabel(\n", + " \"Movie\"\n", + ").ifNotExist().create()" ] }, { @@ -124,7 +130,9 @@ "\n", "g.addEdge(\"ActedIn\", \"1:Al Pacino\", \"2:The Godfather\", {})\n", "g.addEdge(\"ActedIn\", \"1:Al Pacino\", \"2:The Godfather Part II\", {})\n", - "g.addEdge(\"ActedIn\", \"1:Al Pacino\", \"2:The Godfather Coda The Death of Michael Corleone\", {})\n", + "g.addEdge(\n", + " \"ActedIn\", \"1:Al Pacino\", \"2:The Godfather Coda The Death of Michael Corleone\", {}\n", + ")\n", "g.addEdge(\"ActedIn\", \"1:Robert De Niro\", \"2:The Godfather Part II\", {})" ] }, @@ -164,7 +172,7 @@ " password=\"admin\",\n", " address=\"localhost\",\n", " port=8080,\n", - " graph=\"hugegraph\"\n", + " graph=\"hugegraph\",\n", ")" ] }, @@ -228,9 +236,7 @@ "metadata": {}, "outputs": [], "source": [ - "chain = HugeGraphQAChain.from_llm(\n", - " ChatOpenAI(temperature=0), graph=graph, verbose=True\n", - ")" + "chain = HugeGraphQAChain.from_llm(ChatOpenAI(temperature=0), graph=graph, verbose=True)" ] }, { diff --git a/docs/extras/modules/chains/additional/graph_kuzu_qa.ipynb b/docs/extras/modules/chains/additional/graph_kuzu_qa.ipynb index 5a2a5a4dc1b17..2604d0b5f2c9f 100644 --- a/docs/extras/modules/chains/additional/graph_kuzu_qa.ipynb +++ b/docs/extras/modules/chains/additional/graph_kuzu_qa.ipynb @@ -31,6 +31,7 @@ "outputs": [], "source": [ "import kuzu\n", + "\n", "db = kuzu.Database(\"test_db\")\n", "conn = kuzu.Connection(db)" ] @@ -61,7 +62,9 @@ ], "source": [ "conn.execute(\"CREATE NODE TABLE Movie (name STRING, PRIMARY KEY(name))\")\n", - "conn.execute(\"CREATE NODE TABLE Person (name STRING, birthDate STRING, PRIMARY KEY(name))\")\n", + "conn.execute(\n", + " \"CREATE NODE TABLE Person (name STRING, birthDate STRING, PRIMARY KEY(name))\"\n", + ")\n", "conn.execute(\"CREATE REL TABLE ActedIn (FROM Person TO Movie)\")" ] }, @@ -94,11 +97,21 @@ "conn.execute(\"CREATE (:Person {name: 'Robert De Niro', birthDate: '1943-08-17'})\")\n", "conn.execute(\"CREATE (:Movie {name: 'The Godfather'})\")\n", "conn.execute(\"CREATE (:Movie {name: 'The Godfather: Part II'})\")\n", - "conn.execute(\"CREATE (:Movie {name: 'The Godfather Coda: The Death of Michael Corleone'})\")\n", - "conn.execute(\"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather' CREATE (p)-[:ActedIn]->(m)\")\n", - "conn.execute(\"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather: Part II' CREATE (p)-[:ActedIn]->(m)\")\n", - "conn.execute(\"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather Coda: The Death of Michael Corleone' CREATE (p)-[:ActedIn]->(m)\")\n", - "conn.execute(\"MATCH (p:Person), (m:Movie) WHERE p.name = 'Robert De Niro' AND m.name = 'The Godfather: Part II' CREATE (p)-[:ActedIn]->(m)\")" + "conn.execute(\n", + " \"CREATE (:Movie {name: 'The Godfather Coda: The Death of Michael Corleone'})\"\n", + ")\n", + "conn.execute(\n", + " \"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather' CREATE (p)-[:ActedIn]->(m)\"\n", + ")\n", + "conn.execute(\n", + " \"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather: Part II' CREATE (p)-[:ActedIn]->(m)\"\n", + ")\n", + "conn.execute(\n", + " \"MATCH (p:Person), (m:Movie) WHERE p.name = 'Al Pacino' AND m.name = 'The Godfather Coda: The Death of Michael Corleone' CREATE (p)-[:ActedIn]->(m)\"\n", + ")\n", + "conn.execute(\n", + " \"MATCH (p:Person), (m:Movie) WHERE p.name = 'Robert De Niro' AND m.name = 'The Godfather: Part II' CREATE (p)-[:ActedIn]->(m)\"\n", + ")" ] }, { @@ -137,9 +150,7 @@ "metadata": {}, "outputs": [], "source": [ - "chain = KuzuQAChain.from_llm(\n", - " ChatOpenAI(temperature=0), graph=graph, verbose=True\n", - ")" + "chain = KuzuQAChain.from_llm(ChatOpenAI(temperature=0), graph=graph, verbose=True)" ] }, { diff --git a/docs/extras/modules/chains/additional/graph_sparql_qa.ipynb b/docs/extras/modules/chains/additional/graph_sparql_qa.ipynb index 883a325138140..288dc874ecd9b 100644 --- a/docs/extras/modules/chains/additional/graph_sparql_qa.ipynb +++ b/docs/extras/modules/chains/additional/graph_sparql_qa.ipynb @@ -1,301 +1,303 @@ { - "cells": [ - { - "cell_type": "markdown", - "id": "c94240f5", - "metadata": {}, - "source": [ - "# GraphSparqlQAChain\n", - "\n", - "Graph databases are an excellent choice for applications based on network-like models. To standardize the syntax and semantics of such graphs, the W3C recommends Semantic Web Technologies, cp. [Semantic Web](https://www.w3.org/standards/semanticweb/). [SPARQL](https://www.w3.org/TR/sparql11-query/) serves as a query language analogously to SQL or Cypher for these graphs. This notebook demonstrates the application of LLMs as a natural language interface to a graph database by generating SPARQL.\\\n", - "Disclaimer: To date, SPARQL query generation via LLMs is still a bit unstable. Be especially careful with UPDATE queries, which alter the graph." - ] - }, - { - "cell_type": "markdown", - "id": "dbc0ee68", - "metadata": {}, - "source": [ - "There are several sources you can run queries against, including files on the web, files you have available locally, SPARQL endpoints, e.g., [Wikidata](https://www.wikidata.org/wiki/Wikidata:Main_Page), and [triple stores](https://www.w3.org/wiki/LargeTripleStores)." - ] - }, - { - "cell_type": "code", - "execution_count": 1, - "id": "62812aad", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [], - "source": [ - "from langchain.chat_models import ChatOpenAI\n", - "from langchain.chains import GraphSparqlQAChain\n", - "from langchain.graphs import RdfGraph" - ] - }, - { - "cell_type": "code", - "execution_count": 8, - "id": "0928915d", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [], - "source": [ - "graph = RdfGraph(\n", - " source_file=\"http://www.w3.org/People/Berners-Lee/card\",\n", - " standard=\"rdf\",\n", - " local_copy=\"test.ttl\",\n", - ")" - ] - }, - { - "cell_type": "markdown", - "source": [ - "Note that providing a `local_file` is necessary for storing changes locally if the source is read-only." - ], - "metadata": { - "collapsed": false - }, - "id": "7af596b5" - }, - { - "cell_type": "markdown", - "id": "58c1a8ea", - "metadata": {}, - "source": [ - "## Refresh graph schema information\n", - "If the schema of the database changes, you can refresh the schema information needed to generate SPARQL queries." - ] - }, - { - "cell_type": "code", - "execution_count": 9, - "id": "4e3de44f", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [], - "source": [ - "graph.load_schema()" - ] - }, - { - "cell_type": "code", - "execution_count": 10, - "id": "1fe76ccd", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "In the following, each IRI is followed by the local name and optionally its description in parentheses. \n", - "The RDF graph supports the following node types:\n", - " (PersonalProfileDocument, None), (RSAPublicKey, None), (Male, None), (Person, None), (Work, None)\n", - "The RDF graph supports the following relationships:\n", - " (seeAlso, None), (title, None), (mbox_sha1sum, None), (maker, None), (oidcIssuer, None), (publicHomePage, None), (openid, None), (storage, None), (name, None), (country, None), (type, None), (profileHighlightColor, None), (preferencesFile, None), (label, None), (modulus, None), (participant, None), (street2, None), (locality, None), (nick, None), (homepage, None), (license, None), (givenname, None), (street-address, None), (postal-code, None), (street, None), (lat, None), (primaryTopic, None), (fn, None), (location, None), (developer, None), (city, None), (region, None), (member, None), (long, None), (address, None), (family_name, None), (account, None), (workplaceHomepage, None), (title, None), (publicTypeIndex, None), (office, None), (homePage, None), (mbox, None), (preferredURI, None), (profileBackgroundColor, None), (owns, None), (based_near, None), (hasAddress, None), (img, None), (assistant, None), (title, None), (key, None), (inbox, None), (editableProfile, None), (postalCode, None), (weblog, None), (exponent, None), (avatar, None)\n", - "\n" - ] - } - ], - "source": [ - "graph.get_schema" - ] - }, - { - "cell_type": "markdown", - "id": "68a3c677", - "metadata": {}, - "source": [ - "## Querying the graph\n", - "\n", - "Now, you can use the graph SPARQL QA chain to ask questions about the graph." - ] - }, + "cells": [ + { + "cell_type": "markdown", + "id": "c94240f5", + "metadata": {}, + "source": [ + "# GraphSparqlQAChain\n", + "\n", + "Graph databases are an excellent choice for applications based on network-like models. To standardize the syntax and semantics of such graphs, the W3C recommends Semantic Web Technologies, cp. [Semantic Web](https://www.w3.org/standards/semanticweb/). [SPARQL](https://www.w3.org/TR/sparql11-query/) serves as a query language analogously to SQL or Cypher for these graphs. This notebook demonstrates the application of LLMs as a natural language interface to a graph database by generating SPARQL.\\\n", + "Disclaimer: To date, SPARQL query generation via LLMs is still a bit unstable. Be especially careful with UPDATE queries, which alter the graph." + ] + }, + { + "cell_type": "markdown", + "id": "dbc0ee68", + "metadata": {}, + "source": [ + "There are several sources you can run queries against, including files on the web, files you have available locally, SPARQL endpoints, e.g., [Wikidata](https://www.wikidata.org/wiki/Wikidata:Main_Page), and [triple stores](https://www.w3.org/wiki/LargeTripleStores)." + ] + }, + { + "cell_type": "code", + "execution_count": 1, + "id": "62812aad", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [], + "source": [ + "from langchain.chat_models import ChatOpenAI\n", + "from langchain.chains import GraphSparqlQAChain\n", + "from langchain.graphs import RdfGraph" + ] + }, + { + "cell_type": "code", + "execution_count": 8, + "id": "0928915d", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [], + "source": [ + "graph = RdfGraph(\n", + " source_file=\"http://www.w3.org/People/Berners-Lee/card\",\n", + " standard=\"rdf\",\n", + " local_copy=\"test.ttl\",\n", + ")" + ] + }, + { + "cell_type": "markdown", + "source": [ + "Note that providing a `local_file` is necessary for storing changes locally if the source is read-only." + ], + "metadata": { + "collapsed": false + }, + "id": "7af596b5" + }, + { + "cell_type": "markdown", + "id": "58c1a8ea", + "metadata": {}, + "source": [ + "## Refresh graph schema information\n", + "If the schema of the database changes, you can refresh the schema information needed to generate SPARQL queries." + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "id": "4e3de44f", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [], + "source": [ + "graph.load_schema()" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "id": "1fe76ccd", + "metadata": {}, + "outputs": [ { - "cell_type": "code", - "execution_count": 11, - "id": "7476ce98", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [], - "source": [ - "chain = GraphSparqlQAChain.from_llm(\n", - " ChatOpenAI(temperature=0), graph=graph, verbose=True\n", - ")" - ] - }, + "name": "stdout", + "output_type": "stream", + "text": [ + "In the following, each IRI is followed by the local name and optionally its description in parentheses. \n", + "The RDF graph supports the following node types:\n", + " (PersonalProfileDocument, None), (RSAPublicKey, None), (Male, None), (Person, None), (Work, None)\n", + "The RDF graph supports the following relationships:\n", + " (seeAlso, None), (title, None), (mbox_sha1sum, None), (maker, None), (oidcIssuer, None), (publicHomePage, None), (openid, None), (storage, None), (name, None), (country, None), (type, None), (profileHighlightColor, None), (preferencesFile, None), (label, None), (modulus, None), (participant, None), (street2, None), (locality, None), (nick, None), (homepage, None), (license, None), (givenname, None), (street-address, None), (postal-code, None), (street, None), (lat, None), (primaryTopic, None), (fn, None), (location, None), (developer, None), (city, None), (region, None), (member, None), (long, None), (address, None), (family_name, None), (account, None), (workplaceHomepage, None), (title, None), (publicTypeIndex, None), (office, None), (homePage, None), (mbox, None), (preferredURI, None), (profileBackgroundColor, None), (owns, None), (based_near, None), (hasAddress, None), (img, None), (assistant, None), (title, None), (key, None), (inbox, None), (editableProfile, None), (postalCode, None), (weblog, None), (exponent, None), (avatar, None)\n", + "\n" + ] + } + ], + "source": [ + "graph.get_schema" + ] + }, + { + "cell_type": "markdown", + "id": "68a3c677", + "metadata": {}, + "source": [ + "## Querying the graph\n", + "\n", + "Now, you can use the graph SPARQL QA chain to ask questions about the graph." + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "id": "7476ce98", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [], + "source": [ + "chain = GraphSparqlQAChain.from_llm(\n", + " ChatOpenAI(temperature=0), graph=graph, verbose=True\n", + ")" + ] + }, + { + "cell_type": "code", + "execution_count": 12, + "id": "ef8ee27b", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [ { - "cell_type": "code", - "execution_count": 12, - "id": "ef8ee27b", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "\n", - "\n", - "\u001b[1m> Entering new GraphSparqlQAChain chain...\u001b[0m\n", - "Identified intent:\n", - "\u001b[32;1m\u001b[1;3mSELECT\u001b[0m\n", - "Generated SPARQL:\n", - "\u001b[32;1m\u001b[1;3mPREFIX foaf: \n", - "SELECT ?homepage\n", - "WHERE {\n", - " ?person foaf:name \"Tim Berners-Lee\" .\n", - " ?person foaf:workplaceHomepage ?homepage .\n", - "}\u001b[0m\n", - "Full Context:\n", - "\u001b[32;1m\u001b[1;3m[]\u001b[0m\n", - "\n", - "\u001b[1m> Finished chain.\u001b[0m\n" - ] - }, - { - "data": { - "text/plain": [ - "\"Tim Berners-Lee's work homepage is http://www.w3.org/People/Berners-Lee/.\"" - ] - }, - "execution_count": 12, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "chain.run(\"What is Tim Berners-Lee's work homepage?\")" - ] + "name": "stdout", + "output_type": "stream", + "text": [ + "\n", + "\n", + "\u001b[1m> Entering new GraphSparqlQAChain chain...\u001b[0m\n", + "Identified intent:\n", + "\u001b[32;1m\u001b[1;3mSELECT\u001b[0m\n", + "Generated SPARQL:\n", + "\u001b[32;1m\u001b[1;3mPREFIX foaf: \n", + "SELECT ?homepage\n", + "WHERE {\n", + " ?person foaf:name \"Tim Berners-Lee\" .\n", + " ?person foaf:workplaceHomepage ?homepage .\n", + "}\u001b[0m\n", + "Full Context:\n", + "\u001b[32;1m\u001b[1;3m[]\u001b[0m\n", + "\n", + "\u001b[1m> Finished chain.\u001b[0m\n" + ] }, { - "cell_type": "markdown", - "id": "af4b3294", - "metadata": {}, - "source": [ - "## Updating the graph\n", - "\n", - "Analogously, you can update the graph, i.e., insert triples, using natural language." + "data": { + "text/plain": [ + "\"Tim Berners-Lee's work homepage is http://www.w3.org/People/Berners-Lee/.\"" ] - }, + }, + "execution_count": 12, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chain.run(\"What is Tim Berners-Lee's work homepage?\")" + ] + }, + { + "cell_type": "markdown", + "id": "af4b3294", + "metadata": {}, + "source": [ + "## Updating the graph\n", + "\n", + "Analogously, you can update the graph, i.e., insert triples, using natural language." + ] + }, + { + "cell_type": "code", + "execution_count": 14, + "id": "fdf38841", + "metadata": { + "pycharm": { + "is_executing": true + } + }, + "outputs": [ { - "cell_type": "code", - "execution_count": 14, - "id": "fdf38841", - "metadata": { - "pycharm": { - "is_executing": true - } - }, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "\n", - "\n", - "\u001b[1m> Entering new GraphSparqlQAChain chain...\u001b[0m\n", - "Identified intent:\n", - "\u001b[32;1m\u001b[1;3mUPDATE\u001b[0m\n", - "Generated SPARQL:\n", - "\u001b[32;1m\u001b[1;3mPREFIX foaf: \n", - "INSERT {\n", - " ?person foaf:workplaceHomepage .\n", - "}\n", - "WHERE {\n", - " ?person foaf:name \"Timothy Berners-Lee\" .\n", - "}\u001b[0m\n", - "\n", - "\u001b[1m> Finished chain.\u001b[0m\n" - ] - }, - { - "data": { - "text/plain": [ - "'Successfully inserted triples into the graph.'" - ] - }, - "execution_count": 14, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "chain.run(\"Save that the person with the name 'Timothy Berners-Lee' has a work homepage at 'http://www.w3.org/foo/bar/'\")" - ] + "name": "stdout", + "output_type": "stream", + "text": [ + "\n", + "\n", + "\u001b[1m> Entering new GraphSparqlQAChain chain...\u001b[0m\n", + "Identified intent:\n", + "\u001b[32;1m\u001b[1;3mUPDATE\u001b[0m\n", + "Generated SPARQL:\n", + "\u001b[32;1m\u001b[1;3mPREFIX foaf: \n", + "INSERT {\n", + " ?person foaf:workplaceHomepage .\n", + "}\n", + "WHERE {\n", + " ?person foaf:name \"Timothy Berners-Lee\" .\n", + "}\u001b[0m\n", + "\n", + "\u001b[1m> Finished chain.\u001b[0m\n" + ] }, { - "cell_type": "markdown", - "id": "5e0f7fc1", - "metadata": {}, - "source": [ - "Let's verify the results:" + "data": { + "text/plain": [ + "'Successfully inserted triples into the graph.'" ] - }, + }, + "execution_count": 14, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chain.run(\n", + " \"Save that the person with the name 'Timothy Berners-Lee' has a work homepage at 'http://www.w3.org/foo/bar/'\"\n", + ")" + ] + }, + { + "cell_type": "markdown", + "id": "5e0f7fc1", + "metadata": {}, + "source": [ + "Let's verify the results:" + ] + }, + { + "cell_type": "code", + "execution_count": 15, + "id": "f874171b", + "metadata": {}, + "outputs": [ { - "cell_type": "code", - "execution_count": 15, - "id": "f874171b", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[(rdflib.term.URIRef('https://www.w3.org/'),),\n", - " (rdflib.term.URIRef('http://www.w3.org/foo/bar/'),)]" - ] - }, - "execution_count": 15, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "query = (\n", - " \"\"\"PREFIX foaf: \\n\"\"\"\n", - " \"\"\"SELECT ?hp\\n\"\"\"\n", - " \"\"\"WHERE {\\n\"\"\"\n", - " \"\"\" ?person foaf:name \"Timothy Berners-Lee\" . \\n\"\"\"\n", - " \"\"\" ?person foaf:workplaceHomepage ?hp .\\n\"\"\"\n", - " \"\"\"}\"\"\"\n", - ")\n", - "graph.query(query)" + "data": { + "text/plain": [ + "[(rdflib.term.URIRef('https://www.w3.org/'),),\n", + " (rdflib.term.URIRef('http://www.w3.org/foo/bar/'),)]" ] + }, + "execution_count": 15, + "metadata": {}, + "output_type": "execute_result" } - ], - "metadata": { - "kernelspec": { - "display_name": "lc", - "language": "python", - "name": "lc" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.11.4" - } + ], + "source": [ + "query = (\n", + " \"\"\"PREFIX foaf: \\n\"\"\"\n", + " \"\"\"SELECT ?hp\\n\"\"\"\n", + " \"\"\"WHERE {\\n\"\"\"\n", + " \"\"\" ?person foaf:name \"Timothy Berners-Lee\" . \\n\"\"\"\n", + " \"\"\" ?person foaf:workplaceHomepage ?hp .\\n\"\"\"\n", + " \"\"\"}\"\"\"\n", + ")\n", + "graph.query(query)" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "lc", + "language": "python", + "name": "lc" }, - "nbformat": 4, - "nbformat_minor": 5 + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.11.4" + } + }, + "nbformat": 4, + "nbformat_minor": 5 } \ No newline at end of file diff --git a/docs/extras/modules/chains/additional/openai_functions_retrieval_qa.ipynb b/docs/extras/modules/chains/additional/openai_functions_retrieval_qa.ipynb index f664655fd9c64..b3dcbdee5df3c 100644 --- a/docs/extras/modules/chains/additional/openai_functions_retrieval_qa.ipynb +++ b/docs/extras/modules/chains/additional/openai_functions_retrieval_qa.ipynb @@ -38,7 +38,7 @@ "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "texts = text_splitter.split_documents(documents)\n", "for i, text in enumerate(texts):\n", - " text.metadata['source'] = f\"{i}-pl\"\n", + " text.metadata[\"source\"] = f\"{i}-pl\"\n", "embeddings = OpenAIEmbeddings()\n", "docsearch = Chroma.from_documents(texts, embeddings)" ] @@ -97,8 +97,8 @@ "outputs": [], "source": [ "final_qa_chain = StuffDocumentsChain(\n", - " llm_chain=qa_chain, \n", - " document_variable_name='context',\n", + " llm_chain=qa_chain,\n", + " document_variable_name=\"context\",\n", " document_prompt=doc_prompt,\n", ")" ] @@ -111,8 +111,7 @@ "outputs": [], "source": [ "retrieval_qa = RetrievalQA(\n", - " retriever=docsearch.as_retriever(),\n", - " combine_documents_chain=final_qa_chain\n", + " retriever=docsearch.as_retriever(), combine_documents_chain=final_qa_chain\n", ")" ] }, @@ -175,8 +174,8 @@ "outputs": [], "source": [ "final_qa_chain_pydantic = StuffDocumentsChain(\n", - " llm_chain=qa_chain_pydantic, \n", - " document_variable_name='context',\n", + " llm_chain=qa_chain_pydantic,\n", + " document_variable_name=\"context\",\n", " document_prompt=doc_prompt,\n", ")" ] @@ -189,8 +188,7 @@ "outputs": [], "source": [ "retrieval_qa_pydantic = RetrievalQA(\n", - " retriever=docsearch.as_retriever(),\n", - " combine_documents_chain=final_qa_chain_pydantic\n", + " retriever=docsearch.as_retriever(), combine_documents_chain=final_qa_chain_pydantic\n", ")" ] }, @@ -235,6 +233,7 @@ "from langchain.chains import ConversationalRetrievalChain\n", "from langchain.memory import ConversationBufferMemory\n", "from langchain.chains import LLMChain\n", + "\n", "memory = ConversationBufferMemory(memory_key=\"chat_history\", return_messages=True)\n", "_template = \"\"\"Given the following conversation and a follow up question, rephrase the follow up question to be a standalone question, in its original language.\\\n", "Make sure to avoid using any unclear pronouns.\n", @@ -258,10 +257,10 @@ "outputs": [], "source": [ "qa = ConversationalRetrievalChain(\n", - " question_generator=condense_question_chain, \n", + " question_generator=condense_question_chain,\n", " retriever=docsearch.as_retriever(),\n", - " memory=memory, \n", - " combine_docs_chain=final_qa_chain\n", + " memory=memory,\n", + " combine_docs_chain=final_qa_chain,\n", ")" ] }, @@ -389,7 +388,9 @@ " \"\"\"An answer to the question being asked, with sources.\"\"\"\n", "\n", " answer: str = Field(..., description=\"Answer to the question that was asked\")\n", - " countries_referenced: List[str] = Field(..., description=\"All of the countries mentioned in the sources\")\n", + " countries_referenced: List[str] = Field(\n", + " ..., description=\"All of the countries mentioned in the sources\"\n", + " )\n", " sources: List[str] = Field(\n", " ..., description=\"List of sources used to answer the question\"\n", " )\n", @@ -405,20 +406,23 @@ " HumanMessage(content=\"Answer question using the following context\"),\n", " HumanMessagePromptTemplate.from_template(\"{context}\"),\n", " HumanMessagePromptTemplate.from_template(\"Question: {question}\"),\n", - " HumanMessage(content=\"Tips: Make sure to answer in the correct format. Return all of the countries mentioned in the sources in uppercase characters.\"),\n", + " HumanMessage(\n", + " content=\"Tips: Make sure to answer in the correct format. Return all of the countries mentioned in the sources in uppercase characters.\"\n", + " ),\n", "]\n", "\n", "chain_prompt = ChatPromptTemplate(messages=prompt_messages)\n", "\n", - "qa_chain_pydantic = create_qa_with_structure_chain(llm, CustomResponseSchema, output_parser=\"pydantic\", prompt=chain_prompt)\n", + "qa_chain_pydantic = create_qa_with_structure_chain(\n", + " llm, CustomResponseSchema, output_parser=\"pydantic\", prompt=chain_prompt\n", + ")\n", "final_qa_chain_pydantic = StuffDocumentsChain(\n", " llm_chain=qa_chain_pydantic,\n", - " document_variable_name='context',\n", + " document_variable_name=\"context\",\n", " document_prompt=doc_prompt,\n", ")\n", "retrieval_qa_pydantic = RetrievalQA(\n", - " retriever=docsearch.as_retriever(),\n", - " combine_documents_chain=final_qa_chain_pydantic\n", + " retriever=docsearch.as_retriever(), combine_documents_chain=final_qa_chain_pydantic\n", ")\n", "query = \"What did he say about russia\"\n", "retrieval_qa_pydantic.run(query)" diff --git a/docs/extras/modules/chains/additional/openapi_openai.ipynb b/docs/extras/modules/chains/additional/openapi_openai.ipynb index b95fe50bffb8c..bb1cbce5935eb 100644 --- a/docs/extras/modules/chains/additional/openapi_openai.ipynb +++ b/docs/extras/modules/chains/additional/openapi_openai.ipynb @@ -35,7 +35,9 @@ "metadata": {}, "outputs": [], "source": [ - "chain = get_openapi_chain(\"https://www.klarna.com/us/shopping/public/openai/v0/api-docs/\")" + "chain = get_openapi_chain(\n", + " \"https://www.klarna.com/us/shopping/public/openai/v0/api-docs/\"\n", + ")" ] }, { @@ -186,7 +188,9 @@ }, "outputs": [], "source": [ - "chain = get_openapi_chain(\"https://gist.githubusercontent.com/roaldnefs/053e505b2b7a807290908fe9aa3e1f00/raw/0a212622ebfef501163f91e23803552411ed00e4/openapi.yaml\")" + "chain = get_openapi_chain(\n", + " \"https://gist.githubusercontent.com/roaldnefs/053e505b2b7a807290908fe9aa3e1f00/raw/0a212622ebfef501163f91e23803552411ed00e4/openapi.yaml\"\n", + ")" ] }, { diff --git a/docs/extras/modules/chains/popular/openai_functions.ipynb b/docs/extras/modules/chains/popular/openai_functions.ipynb index dc74956f86645..44571cfb078d2 100644 --- a/docs/extras/modules/chains/popular/openai_functions.ipynb +++ b/docs/extras/modules/chains/popular/openai_functions.ipynb @@ -22,7 +22,8 @@ "from typing import Optional\n", "\n", "from langchain.chains.openai_functions import (\n", - " create_openai_fn_chain, create_structured_output_chain\n", + " create_openai_fn_chain,\n", + " create_structured_output_chain,\n", ")\n", "from langchain.chat_models import ChatOpenAI\n", "from langchain.prompts import ChatPromptTemplate, HumanMessagePromptTemplate\n", @@ -58,8 +59,10 @@ "source": [ "from pydantic import BaseModel, Field\n", "\n", + "\n", "class Person(BaseModel):\n", " \"\"\"Identifying information about a person.\"\"\"\n", + "\n", " name: str = Field(..., description=\"The person's name\")\n", " age: int = Field(..., description=\"The person's age\")\n", " fav_food: Optional[str] = Field(None, description=\"The person's favorite food\")" @@ -103,13 +106,15 @@ "llm = ChatOpenAI(model=\"gpt-3.5-turbo-0613\", temperature=0)\n", "\n", "prompt_msgs = [\n", - " SystemMessage(\n", - " content=\"You are a world class algorithm for extracting information in structured formats.\"\n", - " ),\n", - " HumanMessage(content=\"Use the given format to extract information from the following input:\"),\n", - " HumanMessagePromptTemplate.from_template(\"{input}\"),\n", - " HumanMessage(content=\"Tips: Make sure to answer in the correct format\"),\n", - " ]\n", + " SystemMessage(\n", + " content=\"You are a world class algorithm for extracting information in structured formats.\"\n", + " ),\n", + " HumanMessage(\n", + " content=\"Use the given format to extract information from the following input:\"\n", + " ),\n", + " HumanMessagePromptTemplate.from_template(\"{input}\"),\n", + " HumanMessage(content=\"Tips: Make sure to answer in the correct format\"),\n", + "]\n", "prompt = ChatPromptTemplate(messages=prompt_msgs)\n", "\n", "chain = create_structured_output_chain(Person, llm, prompt, verbose=True)\n", @@ -162,12 +167,17 @@ "source": [ "from typing import Sequence\n", "\n", + "\n", "class People(BaseModel):\n", " \"\"\"Identifying information about all people in a text.\"\"\"\n", + "\n", " people: Sequence[Person] = Field(..., description=\"The people in the text\")\n", - " \n", + "\n", + "\n", "chain = create_structured_output_chain(People, llm, prompt, verbose=True)\n", - "chain.run(\"Sally is 13, Joey just turned 12 and loves spinach. Caroline is 10 years older than Sally, so she's 23.\")" + "chain.run(\n", + " \"Sally is 13, Joey just turned 12 and loves spinach. Caroline is 10 years older than Sally, so she's 23.\"\n", + ")" ] }, { @@ -192,27 +202,16 @@ " \"description\": \"Identifying information about a person.\",\n", " \"type\": \"object\",\n", " \"properties\": {\n", - " \"name\": {\n", - " \"title\": \"Name\",\n", - " \"description\": \"The person's name\",\n", - " \"type\": \"string\"\n", - " },\n", - " \"age\": {\n", - " \"title\": \"Age\",\n", - " \"description\": \"The person's age\",\n", - " \"type\": \"integer\"\n", - " },\n", - " \"fav_food\": {\n", - " \"title\": \"Fav Food\",\n", - " \"description\": \"The person's favorite food\",\n", - " \"type\": \"string\"\n", - " }\n", + " \"name\": {\"title\": \"Name\", \"description\": \"The person's name\", \"type\": \"string\"},\n", + " \"age\": {\"title\": \"Age\", \"description\": \"The person's age\", \"type\": \"integer\"},\n", + " \"fav_food\": {\n", + " \"title\": \"Fav Food\",\n", + " \"description\": \"The person's favorite food\",\n", + " \"type\": \"string\",\n", + " },\n", " },\n", - " \"required\": [\n", - " \"name\",\n", - " \"age\"\n", - " ]\n", - "}\n" + " \"required\": [\"name\", \"age\"],\n", + "}" ] }, { @@ -286,13 +285,15 @@ "source": [ "class RecordPerson(BaseModel):\n", " \"\"\"Record some identifying information about a pe.\"\"\"\n", + "\n", " name: str = Field(..., description=\"The person's name\")\n", " age: int = Field(..., description=\"The person's age\")\n", " fav_food: Optional[str] = Field(None, description=\"The person's favorite food\")\n", "\n", - " \n", + "\n", "class RecordDog(BaseModel):\n", " \"\"\"Record some identifying information about a dog.\"\"\"\n", + "\n", " name: str = Field(..., description=\"The dog's name\")\n", " color: str = Field(..., description=\"The dog's color\")\n", " fav_food: Optional[str] = Field(None, description=\"The dog's favorite food\")" @@ -333,10 +334,10 @@ ], "source": [ "prompt_msgs = [\n", - " SystemMessage(\n", - " content=\"You are a world class algorithm for recording entities\"\n", + " SystemMessage(content=\"You are a world class algorithm for recording entities\"),\n", + " HumanMessage(\n", + " content=\"Make calls to the relevant function to record the entities in the following input:\"\n", " ),\n", - " HumanMessage(content=\"Make calls to the relevant function to record the entities in the following input:\"),\n", " HumanMessagePromptTemplate.from_template(\"{input}\"),\n", " HumanMessage(content=\"Tips: Make sure to answer in the correct format\"),\n", "]\n", @@ -393,11 +394,16 @@ "source": [ "class OptionalFavFood(BaseModel):\n", " \"\"\"Either a food or null.\"\"\"\n", - " food: Optional[str] = Field(None, description=\"Either the name of a food or null. Should be null if the food isn't known.\")\n", + "\n", + " food: Optional[str] = Field(\n", + " None,\n", + " description=\"Either the name of a food or null. Should be null if the food isn't known.\",\n", + " )\n", + "\n", "\n", "def record_person(name: str, age: int, fav_food: OptionalFavFood) -> str:\n", " \"\"\"Record some basic identifying information about a person.\n", - " \n", + "\n", " Args:\n", " name: The person's name.\n", " age: The person's age in years.\n", @@ -405,9 +411,11 @@ " \"\"\"\n", " return f\"Recording person {name} of age {age} with favorite food {fav_food.food}!\"\n", "\n", - " \n", + "\n", "chain = create_openai_fn_chain([record_person], llm, prompt, verbose=True)\n", - "chain.run(\"The most important thing to remember about Tommy, my 12 year old, is that he'll do anything for apple pie.\")" + "chain.run(\n", + " \"The most important thing to remember about Tommy, my 12 year old, is that he'll do anything for apple pie.\"\n", + ")" ] }, { @@ -458,7 +466,7 @@ "source": [ "def record_dog(name: str, color: str, fav_food: OptionalFavFood) -> str:\n", " \"\"\"Record some basic identifying information about a dog.\n", - " \n", + "\n", " Args:\n", " name: The dog's name.\n", " color: The dog's color.\n", @@ -468,7 +476,9 @@ "\n", "\n", "chain = create_openai_fn_chain([record_person, record_dog], llm, prompt, verbose=True)\n", - "chain.run(\"I can't find my dog Henry anywhere, he's a small brown beagle. Could you send a message about him?\")" + "chain.run(\n", + " \"I can't find my dog Henry anywhere, he's a small brown beagle. Could you send a message about him?\"\n", + ")" ] }, { diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/brave_search.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/brave_search.ipynb index db3106367a225..11a819d748dcd 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/brave_search.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/brave_search.ipynb @@ -77,7 +77,9 @@ } ], "source": [ - "loader = BraveSearchLoader(query=\"obama middle name\", api_key=api_key, search_kwargs={\"count\": 3})\n", + "loader = BraveSearchLoader(\n", + " query=\"obama middle name\", api_key=api_key, search_kwargs={\"count\": 3}\n", + ")\n", "docs = loader.load()\n", "len(docs)" ] diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/datadog_logs.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/datadog_logs.ipynb index 86fd433b9b80e..ed80b15b8865c 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/datadog_logs.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/datadog_logs.ipynb @@ -42,9 +42,9 @@ " query=query,\n", " api_key=DD_API_KEY,\n", " app_key=DD_APP_KEY,\n", - " from_time=1688732708951, # Optional, timestamp in milliseconds\n", - " to_time=1688736308951, # Optional, timestamp in milliseconds\n", - " limit=100, # Optional, default is 100\n", + " from_time=1688732708951, # Optional, timestamp in milliseconds\n", + " to_time=1688736308951, # Optional, timestamp in milliseconds\n", + " limit=100, # Optional, default is 100\n", ")" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/google_drive.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/google_drive.ipynb index fe59db46ce839..e7cda8f0617c5 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/google_drive.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/google_drive.ipynb @@ -126,11 +126,11 @@ "metadata": {}, "outputs": [], "source": [ - "file_id=\"1x9WBtFPWMEAdjcJzPScRsjpjQvpSo_kz\"\n", + "file_id = \"1x9WBtFPWMEAdjcJzPScRsjpjQvpSo_kz\"\n", "loader = GoogleDriveLoader(\n", " file_ids=[file_id],\n", " file_loader_cls=UnstructuredFileIOLoader,\n", - " file_loader_kwargs={\"mode\": \"elements\"}\n", + " file_loader_kwargs={\"mode\": \"elements\"},\n", ")" ] }, @@ -180,11 +180,11 @@ "metadata": {}, "outputs": [], "source": [ - "folder_id=\"1asMOHY1BqBS84JcRbOag5LOJac74gpmD\"\n", + "folder_id = \"1asMOHY1BqBS84JcRbOag5LOJac74gpmD\"\n", "loader = GoogleDriveLoader(\n", " folder_id=folder_id,\n", " file_loader_cls=UnstructuredFileIOLoader,\n", - " file_loader_kwargs={\"mode\": \"elements\"}\n", + " file_loader_kwargs={\"mode\": \"elements\"},\n", ")" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/grobid.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/grobid.ipynb index 05eb38a0bbf7b..96bf6b8ddb4fb 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/grobid.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/grobid.ipynb @@ -101,7 +101,7 @@ " \"../Papers/\",\n", " glob=\"*\",\n", " suffixes=[\".pdf\"],\n", - " parser= GrobidParser(segment_sentences=False)\n", + " parser=GrobidParser(segment_sentences=False),\n", ")\n", "docs = loader.load()" ] diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/merge_doc_loader.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/merge_doc_loader.ipynb index 2144c777cb382..5270400ef41cc 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/merge_doc_loader.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/merge_doc_loader.ipynb @@ -18,7 +18,10 @@ "outputs": [], "source": [ "from langchain.document_loaders import WebBaseLoader\n", - "loader_web = WebBaseLoader(\"https://github.com/basecamp/handbook/blob/master/37signals-is-you.md\")" + "\n", + "loader_web = WebBaseLoader(\n", + " \"https://github.com/basecamp/handbook/blob/master/37signals-is-you.md\"\n", + ")" ] }, { @@ -29,6 +32,7 @@ "outputs": [], "source": [ "from langchain.document_loaders import PyPDFLoader\n", + "\n", "loader_pdf = PyPDFLoader(\"../MachineLearning-Lecture01.pdf\")" ] }, @@ -40,7 +44,8 @@ "outputs": [], "source": [ "from langchain.document_loaders.merge import MergedDataLoader\n", - "loader_all=MergedDataLoader(loaders=[loader_web,loader_pdf])" + "\n", + "loader_all = MergedDataLoader(loaders=[loader_web, loader_pdf])" ] }, { @@ -50,7 +55,7 @@ "metadata": {}, "outputs": [], "source": [ - "docs_all=loader_all.load()" + "docs_all = loader_all.load()" ] }, { diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/mhtml.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/mhtml.ipynb index 12ebd2a3e1f82..afad82a05148a 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/mhtml.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/mhtml.ipynb @@ -36,7 +36,9 @@ ], "source": [ "# Create a new loader object for the MHTML file\n", - "loader = MHTMLLoader(file_path='../../../../../../tests/integration_tests/examples/example.mht')\n", + "loader = MHTMLLoader(\n", + " file_path=\"../../../../../../tests/integration_tests/examples/example.mht\"\n", + ")\n", "\n", "# Load the document from the file\n", "documents = loader.load()\n", diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/open_city_data.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/open_city_data.ipynb index 0cd457e4f7fa9..7a9f86c8d941b 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/open_city_data.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/open_city_data.ipynb @@ -53,11 +53,9 @@ "metadata": {}, "outputs": [], "source": [ - "dataset = \"vw6y-z8j6\" # 311 data\n", - "dataset = \"tmnf-yvry\" # crime data\n", - "loader = OpenCityDataLoader(city_id=\"data.sfgov.org\",\n", - " dataset_id=dataset,\n", - " limit=2000)" + "dataset = \"vw6y-z8j6\" # 311 data\n", + "dataset = \"tmnf-yvry\" # crime data\n", + "loader = OpenCityDataLoader(city_id=\"data.sfgov.org\", dataset_id=dataset, limit=2000)" ] }, { diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/org_mode.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/org_mode.ipynb index b749e6be1a6ee..e8146a9eb526f 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/org_mode.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/org_mode.ipynb @@ -33,9 +33,7 @@ "metadata": {}, "outputs": [], "source": [ - "loader = UnstructuredOrgModeLoader(\n", - " file_path=\"example_data/README.org\", mode=\"elements\"\n", - ")\n", + "loader = UnstructuredOrgModeLoader(file_path=\"example_data/README.org\", mode=\"elements\")\n", "docs = loader.load()" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/pandas_dataframe.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/pandas_dataframe.ipynb index 76402681741aa..e3d268c9e184f 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/pandas_dataframe.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/pandas_dataframe.ipynb @@ -239,7 +239,7 @@ } ], "source": [ - "# Use lazy load for larger table, which won't read the full table into memory \n", + "# Use lazy load for larger table, which won't read the full table into memory\n", "for i in loader.lazy_load():\n", " print(i)" ] diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/recursive_url_loader.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/recursive_url_loader.ipynb index b35b814af4b56..06903220f699e 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/recursive_url_loader.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/recursive_url_loader.ipynb @@ -49,9 +49,9 @@ "metadata": {}, "outputs": [], "source": [ - "url = 'https://js.langchain.com/docs/modules/memory/examples/'\n", - "loader=RecursiveUrlLoader(url=url)\n", - "docs=loader.load()" + "url = \"https://js.langchain.com/docs/modules/memory/examples/\"\n", + "loader = RecursiveUrlLoader(url=url)\n", + "docs = loader.load()" ] }, { @@ -138,10 +138,10 @@ "metadata": {}, "outputs": [], "source": [ - "url = 'https://js.langchain.com/docs/'\n", - "exclude_dirs=['https://js.langchain.com/docs/api/']\n", - "loader=RecursiveUrlLoader(url=url,exclude_dirs=exclude_dirs)\n", - "docs=loader.load()" + "url = \"https://js.langchain.com/docs/\"\n", + "exclude_dirs = [\"https://js.langchain.com/docs/api/\"]\n", + "loader = RecursiveUrlLoader(url=url, exclude_dirs=exclude_dirs)\n", + "docs = loader.load()" ] }, { diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/rst.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/rst.ipynb index 1e2b6dd137234..a88bb7f9c4b8c 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/rst.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/rst.ipynb @@ -33,9 +33,7 @@ "metadata": {}, "outputs": [], "source": [ - "loader = UnstructuredRSTLoader(\n", - " file_path=\"example_data/README.rst\", mode=\"elements\"\n", - ")\n", + "loader = UnstructuredRSTLoader(file_path=\"example_data/README.rst\", mode=\"elements\")\n", "docs = loader.load()" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/source_code.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/source_code.ipynb index bdf3cec2252c3..78e375617de79 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/source_code.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/source_code.ipynb @@ -30,7 +30,8 @@ "outputs": [], "source": [ "import warnings\n", - "warnings.filterwarnings('ignore')\n", + "\n", + "warnings.filterwarnings(\"ignore\")\n", "from pprint import pprint\n", "from langchain.text_splitter import Language\n", "from langchain.document_loaders.generic import GenericLoader\n", @@ -48,7 +49,7 @@ " \"./example_data/source_code\",\n", " glob=\"*\",\n", " suffixes=[\".py\", \".js\"],\n", - " parser=LanguageParser()\n", + " parser=LanguageParser(),\n", ")\n", "docs = loader.load()" ] @@ -200,7 +201,7 @@ " \"./example_data/source_code\",\n", " glob=\"*\",\n", " suffixes=[\".py\"],\n", - " parser=LanguageParser(language=Language.PYTHON, parser_threshold=1000)\n", + " parser=LanguageParser(language=Language.PYTHON, parser_threshold=1000),\n", ")\n", "docs = loader.load()" ] @@ -281,7 +282,7 @@ " \"./example_data/source_code\",\n", " glob=\"*\",\n", " suffixes=[\".js\"],\n", - " parser=LanguageParser(language=Language.JS)\n", + " parser=LanguageParser(language=Language.JS),\n", ")\n", "docs = loader.load()" ] diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_directory.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_directory.ipynb index c2189b7ccdf9f..95dcdb0bc688e 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_directory.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_directory.ipynb @@ -43,10 +43,10 @@ "outputs": [], "source": [ "conf = CosConfig(\n", - " Region=\"your cos region\",\n", - " SecretId=\"your cos secret_id\",\n", - " SecretKey=\"your cos secret_key\",\n", - " )\n", + " Region=\"your cos region\",\n", + " SecretId=\"your cos secret_id\",\n", + " SecretKey=\"your cos secret_key\",\n", + ")\n", "loader = TencentCOSDirectoryLoader(conf=conf, bucket=\"you_cos_bucket\")" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_file.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_file.ipynb index a8c11cf2b5151..c06e67588993c 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_file.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/tencent_cos_file.ipynb @@ -43,10 +43,10 @@ "outputs": [], "source": [ "conf = CosConfig(\n", - " Region=\"your cos region\",\n", - " SecretId=\"your cos secret_id\",\n", - " SecretKey=\"your cos secret_key\",\n", - " )\n", + " Region=\"your cos region\",\n", + " SecretId=\"your cos secret_id\",\n", + " SecretKey=\"your cos secret_key\",\n", + ")\n", "loader = TencentCOSFileLoader(conf=conf, bucket=\"you_cos_bucket\", key=\"fake.docx\")" ] }, diff --git a/docs/extras/modules/data_connection/document_loaders/integrations/web_base.ipynb b/docs/extras/modules/data_connection/document_loaders/integrations/web_base.ipynb index ca7937b1de742..cdf39ef8de24b 100644 --- a/docs/extras/modules/data_connection/document_loaders/integrations/web_base.ipynb +++ b/docs/extras/modules/data_connection/document_loaders/integrations/web_base.ipynb @@ -1,279 +1,280 @@ { - "cells": [ - { - "cell_type": "markdown", - "id": "bf920da0", - "metadata": {}, - "source": [ - "# WebBaseLoader\n", - "\n", - "This covers how to use `WebBaseLoader` to load all text from `HTML` webpages into a document format that we can use downstream. For more custom logic for loading webpages look at some child class examples such as `IMSDbLoader`, `AZLyricsLoader`, and `CollegeConfidentialLoader`" - ] - }, - { - "cell_type": "code", - "execution_count": 1, - "id": "00b6de21", - "metadata": {}, - "outputs": [], - "source": [ - "from langchain.document_loaders import WebBaseLoader" - ] - }, - { - "cell_type": "code", - "execution_count": 2, - "id": "0231df35", - "metadata": {}, - "outputs": [], - "source": [ - "loader = WebBaseLoader(\"https://www.espn.com/\")" - ] - }, - { - "cell_type": "markdown", - "id": "c162b300-5f4b-4e37-bab3-17f590fc07cc", - "metadata": {}, - "source": [ - "To bypass SSL verification errors during fetching, you can set the \"verify\" option:\n", - "\n", - "loader.requests_kwargs = {'verify':False}" - ] - }, - { - "cell_type": "code", - "execution_count": 3, - "id": "f06bdc4e", - "metadata": {}, - "outputs": [], - "source": [ - "data = loader.load()" - ] - }, - { - "cell_type": "code", - "execution_count": 4, - "id": "a390d79f", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer\u2026MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most8h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington\u2019s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court10h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: \u00a9 ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0)]" - ] - }, - "execution_count": 4, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "data" - ] - }, - { - "cell_type": "code", - "execution_count": 11, - "id": "878179f7", - "metadata": {}, - "outputs": [], - "source": [ - "\"\"\"\n", - "# Use this piece of code for testing new custom BeautifulSoup parsers\n", - "\n", - "import requests\n", - "from bs4 import BeautifulSoup\n", - "\n", - "html_doc = requests.get(\"{INSERT_NEW_URL_HERE}\")\n", - "soup = BeautifulSoup(html_doc.text, 'html.parser')\n", - "\n", - "# Beautiful soup logic to be exported to langchain.document_loaders.webpage.py\n", - "# Example: transcript = soup.select_one(\"td[class='scrtext']\").text\n", - "# BS4 documentation can be found here: https://www.crummy.com/software/BeautifulSoup/bs4/doc/\n", - "\n", - "\"\"\";" - ] - }, - { - "cell_type": "markdown", - "id": "150988e6", - "metadata": {}, - "source": [ - "## Loading multiple webpages\n", - "\n", - "You can also load multiple webpages at once by passing in a list of urls to the loader. This will return a list of documents in the same order as the urls passed in." - ] - }, - { - "cell_type": "code", - "execution_count": 4, - "id": "e25bbd3b", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer\u2026MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most7h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington\u2019s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court9h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: \u00a9 ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0),\n", - " Document(page_content='GoogleSearch Images Maps Play YouTube News Gmail Drive More \u00bbWeb History | Settings | Sign in\\xa0Advanced searchAdvertisingBusiness SolutionsAbout Google\u00a9 2023 - Privacy - Terms ', lookup_str='', metadata={'source': 'https://google.com'}, lookup_index=0)]" - ] - }, - "execution_count": 4, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "loader = WebBaseLoader([\"https://www.espn.com/\", \"https://google.com\"])\n", - "docs = loader.load()\n", - "docs" - ] - }, + "cells": [ + { + "cell_type": "markdown", + "id": "bf920da0", + "metadata": {}, + "source": [ + "# WebBaseLoader\n", + "\n", + "This covers how to use `WebBaseLoader` to load all text from `HTML` webpages into a document format that we can use downstream. For more custom logic for loading webpages look at some child class examples such as `IMSDbLoader`, `AZLyricsLoader`, and `CollegeConfidentialLoader`" + ] + }, + { + "cell_type": "code", + "execution_count": 1, + "id": "00b6de21", + "metadata": {}, + "outputs": [], + "source": [ + "from langchain.document_loaders import WebBaseLoader" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "id": "0231df35", + "metadata": {}, + "outputs": [], + "source": [ + "loader = WebBaseLoader(\"https://www.espn.com/\")" + ] + }, + { + "cell_type": "markdown", + "id": "c162b300-5f4b-4e37-bab3-17f590fc07cc", + "metadata": {}, + "source": [ + "To bypass SSL verification errors during fetching, you can set the \"verify\" option:\n", + "\n", + "loader.requests_kwargs = {'verify':False}" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "id": "f06bdc4e", + "metadata": {}, + "outputs": [], + "source": [ + "data = loader.load()" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "id": "a390d79f", + "metadata": {}, + "outputs": [ { - "cell_type": "markdown", - "id": "641be294", - "metadata": {}, - "source": [ - "### Load multiple urls concurrently\n", - "\n", - "You can speed up the scraping process by scraping and parsing multiple urls concurrently.\n", - "\n", - "There are reasonable limits to concurrent requests, defaulting to 2 per second. If you aren't concerned about being a good citizen, or you control the server you are scraping and don't care about load, you can change the `requests_per_second` parameter to increase the max concurrent requests. Note, while this will speed up the scraping process, but may cause the server to block you. Be careful!" + "data": { + "text/plain": [ + "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer…MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most8h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington’s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court10h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: © ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0)]" ] - }, + }, + "execution_count": 4, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "data" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "id": "878179f7", + "metadata": {}, + "outputs": [], + "source": [ + "\"\"\"\n", + "# Use this piece of code for testing new custom BeautifulSoup parsers\n", + "\n", + "import requests\n", + "from bs4 import BeautifulSoup\n", + "\n", + "html_doc = requests.get(\"{INSERT_NEW_URL_HERE}\")\n", + "soup = BeautifulSoup(html_doc.text, 'html.parser')\n", + "\n", + "# Beautiful soup logic to be exported to langchain.document_loaders.webpage.py\n", + "# Example: transcript = soup.select_one(\"td[class='scrtext']\").text\n", + "# BS4 documentation can be found here: https://www.crummy.com/software/BeautifulSoup/bs4/doc/\n", + "\n", + "\"\"\";" + ] + }, + { + "cell_type": "markdown", + "id": "150988e6", + "metadata": {}, + "source": [ + "## Loading multiple webpages\n", + "\n", + "You can also load multiple webpages at once by passing in a list of urls to the loader. This will return a list of documents in the same order as the urls passed in." + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "id": "e25bbd3b", + "metadata": {}, + "outputs": [ { - "cell_type": "code", - "execution_count": 9, - "id": "9f9cf30f", - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Requirement already satisfied: nest_asyncio in /Users/harrisonchase/.pyenv/versions/3.9.1/envs/langchain/lib/python3.9/site-packages (1.5.6)\n" - ] - } - ], - "source": [ - "!pip install nest_asyncio\n", - "\n", - "# fixes a bug with asyncio and jupyter\n", - "import nest_asyncio\n", - "\n", - "nest_asyncio.apply()" + "data": { + "text/plain": [ + "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer…MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most7h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington’s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court9h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: © ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0),\n", + " Document(page_content='GoogleSearch Images Maps Play YouTube News Gmail Drive More »Web History | Settings | Sign in\\xa0Advanced searchAdvertisingBusiness SolutionsAbout Google© 2023 - Privacy - Terms ', lookup_str='', metadata={'source': 'https://google.com'}, lookup_index=0)]" ] - }, + }, + "execution_count": 4, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "loader = WebBaseLoader([\"https://www.espn.com/\", \"https://google.com\"])\n", + "docs = loader.load()\n", + "docs" + ] + }, + { + "cell_type": "markdown", + "id": "641be294", + "metadata": {}, + "source": [ + "### Load multiple urls concurrently\n", + "\n", + "You can speed up the scraping process by scraping and parsing multiple urls concurrently.\n", + "\n", + "There are reasonable limits to concurrent requests, defaulting to 2 per second. If you aren't concerned about being a good citizen, or you control the server you are scraping and don't care about load, you can change the `requests_per_second` parameter to increase the max concurrent requests. Note, while this will speed up the scraping process, but may cause the server to block you. Be careful!" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "id": "9f9cf30f", + "metadata": {}, + "outputs": [ { - "cell_type": "code", - "execution_count": 10, - "id": "49586eac", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer\u2026MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most7h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington\u2019s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court9h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: \u00a9 ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0),\n", - " Document(page_content='GoogleSearch Images Maps Play YouTube News Gmail Drive More \u00bbWeb History | Settings | Sign in\\xa0Advanced searchAdvertisingBusiness SolutionsAbout Google\u00a9 2023 - Privacy - Terms ', lookup_str='', metadata={'source': 'https://google.com'}, lookup_index=0)]" - ] - }, - "execution_count": 10, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "loader = WebBaseLoader([\"https://www.espn.com/\", \"https://google.com\"])\n", - "loader.requests_per_second = 1\n", - "docs = loader.aload()\n", - "docs" - ] - }, + "name": "stdout", + "output_type": "stream", + "text": [ + "Requirement already satisfied: nest_asyncio in /Users/harrisonchase/.pyenv/versions/3.9.1/envs/langchain/lib/python3.9/site-packages (1.5.6)\n" + ] + } + ], + "source": [ + "!pip install nest_asyncio\n", + "\n", + "# fixes a bug with asyncio and jupyter\n", + "import nest_asyncio\n", + "\n", + "nest_asyncio.apply()" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "id": "49586eac", + "metadata": {}, + "outputs": [ { - "cell_type": "markdown", - "id": "e337b130", - "metadata": {}, - "source": [ - "## Loading a xml file, or using a different BeautifulSoup parser\n", - "\n", - "You can also look at `SitemapLoader` for an example of how to load a sitemap file, which is an example of using this feature." + "data": { + "text/plain": [ + "[Document(page_content=\"\\n\\n\\n\\n\\n\\n\\n\\n\\nESPN - Serving Sports Fans. Anytime. Anywhere.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n Skip to main content\\n \\n\\n Skip to navigation\\n \\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n<\\n\\n>\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nMenuESPN\\n\\n\\nSearch\\n\\n\\n\\nscores\\n\\n\\n\\nNFLNBANCAAMNCAAWNHLSoccer…MLBNCAAFGolfTennisSports BettingBoxingCFLNCAACricketF1HorseLLWSMMANASCARNBA G LeagueOlympic SportsRacingRN BBRN FBRugbyWNBAWorld Baseball ClassicWWEX GamesXFLMore ESPNFantasyListenWatchESPN+\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n \\n\\nSUBSCRIBE NOW\\n\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\n\\n\\n\\n\\nFavorites\\n\\n\\n\\n\\n\\n\\n Manage Favorites\\n \\n\\n\\n\\nCustomize ESPNSign UpLog InESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nAre you ready for Opening Day? Here's your guide to MLB's offseason chaosWait, Jacob deGrom is on the Rangers now? Xander Bogaerts and Trea Turner signed where? And what about Carlos Correa? Yeah, you're going to need to read up before Opening Day.12hESPNIllustration by ESPNEverything you missed in the MLB offseason3h2:33World Series odds, win totals, props for every teamPlay fantasy baseball for free!TOP HEADLINESQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersLAMAR WANTS OUT OF BALTIMOREMarcus Spears identifies the two teams that need Lamar Jackson the most7h2:00Would Lamar sit out? Will Ravens draft a QB? Jackson trade request insightsLamar Jackson has asked Baltimore to trade him, but Ravens coach John Harbaugh hopes the QB will be back.3hJamison HensleyBallard, Colts will consider trading for QB JacksonJackson to Indy? Washington? Barnwell ranks the QB's trade fitsSNYDER'S TUMULTUOUS 24-YEAR RUNHow Washington’s NFL franchise sank on and off the field under owner Dan SnyderSnyder purchased one of the NFL's marquee franchises in 1999. Twenty-four years later, and with the team up for sale, he leaves a legacy of on-field futility and off-field scandal.13hJohn KeimESPNIOWA STAR STEPS UP AGAINJ-Will: Caitlin Clark is the biggest brand in college sports right now8h0:47'The better the opponent, the better she plays': Clark draws comparisons to TaurasiCaitlin Clark's performance on Sunday had longtime observers going back decades to find comparisons.16hKevin PeltonWOMEN'S ELITE EIGHT SCOREBOARDMONDAY'S GAMESCheck your bracket!NBA DRAFTHow top prospects fared on the road to the Final FourThe 2023 NCAA tournament is down to four teams, and ESPN's Jonathan Givony recaps the players who saw their NBA draft stock change.11hJonathan GivonyAndy Lyons/Getty ImagesTALKING BASKETBALLWhy AD needs to be more assertive with LeBron on the court9h1:33Why Perk won't blame Kyrie for Mavs' woes8h1:48WHERE EVERY TEAM STANDSNew NFL Power Rankings: Post-free-agency 1-32 poll, plus underrated offseason movesThe free agent frenzy has come and gone. Which teams have improved their 2023 outlook, and which teams have taken a hit?12hNFL Nation reportersIllustration by ESPNTHE BUCK STOPS WITH BELICHICKBruschi: Fair to criticize Bill Belichick for Patriots' struggles10h1:27 Top HeadlinesQB Jackson has requested trade from RavensSources: Texas hiring Terry as full-time coachJets GM: No rush on Rodgers; Lamar not optionLove to leave North Carolina, enter transfer portalBelichick to angsty Pats fans: See last 25 yearsEmbiid out, Harden due back vs. Jokic, NuggetsLynch: Purdy 'earned the right' to start for NinersMan Utd, Wrexham plan July friendly in San DiegoOn paper, Padres overtake DodgersFavorites FantasyManage FavoritesFantasy HomeCustomize ESPNSign UpLog InMarch Madness LiveESPNMarch Madness LiveWatch every men's NCAA tournament game live! ICYMI1:42Austin Peay's coach, pitcher and catcher all ejected after retaliation pitchAustin Peay's pitcher, catcher and coach were all ejected after a pitch was thrown at Liberty's Nathan Keeter, who earlier in the game hit a home run and celebrated while running down the third-base line. Men's Tournament ChallengeIllustration by ESPNMen's Tournament ChallengeCheck your bracket(s) in the 2023 Men's Tournament Challenge, which you can follow throughout the Big Dance. Women's Tournament ChallengeIllustration by ESPNWomen's Tournament ChallengeCheck your bracket(s) in the 2023 Women's Tournament Challenge, which you can follow throughout the Big Dance. Best of ESPN+AP Photo/Lynne SladkyFantasy Baseball ESPN+ Cheat Sheet: Sleepers, busts, rookies and closersYou've read their names all preseason long, it'd be a shame to forget them on draft day. The ESPN+ Cheat Sheet is one way to make sure that doesn't happen.Steph Chambers/Getty ImagesPassan's 2023 MLB season preview: Bold predictions and moreOpening Day is just over a week away -- and Jeff Passan has everything you need to know covered from every possible angle.Photo by Bob Kupbens/Icon Sportswire2023 NFL free agency: Best team fits for unsigned playersWhere could Ezekiel Elliott land? Let's match remaining free agents to teams and find fits for two trade candidates.Illustration by ESPN2023 NFL mock draft: Mel Kiper's first-round pick predictionsMel Kiper Jr. makes his predictions for Round 1 of the NFL draft, including projecting a trade in the top five. Trending NowAnne-Marie Sorvin-USA TODAY SBoston Bruins record tracker: Wins, points, milestonesThe B's are on pace for NHL records in wins and points, along with some individual superlatives as well. Follow along here with our updated tracker.Mandatory Credit: William Purnell-USA TODAY Sports2023 NFL full draft order: AFC, NFC team picks for all roundsStarting with the Carolina Panthers at No. 1 overall, here's the entire 2023 NFL draft broken down round by round. How to Watch on ESPN+Gregory Fisher/Icon Sportswire2023 NCAA men's hockey: Results, bracket, how to watchThe matchups in Tampa promise to be thrillers, featuring plenty of star power, high-octane offense and stellar defense.(AP Photo/Koji Sasahara, File)How to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN, ESPN+Here's everything you need to know about how to watch the PGA Tour, Masters, PGA Championship and FedEx Cup playoffs on ESPN and ESPN+.Hailie Lynch/XFLHow to watch the XFL: 2023 schedule, teams, players, news, moreEvery XFL game will be streamed on ESPN+. Find out when and where else you can watch the eight teams compete. Sign up to play the #1 Fantasy Baseball GameReactivate A LeagueCreate A LeagueJoin a Public LeaguePractice With a Mock DraftSports BettingAP Photo/Mike KropfMarch Madness betting 2023: Bracket odds, lines, tips, moreThe 2023 NCAA tournament brackets have finally been released, and we have everything you need to know to make a bet on all of the March Madness games. Sign up to play the #1 Fantasy game!Create A LeagueJoin Public LeagueReactivateMock Draft Now\\n\\nESPN+\\n\\n\\n\\n\\nNHL: Select Games\\n\\n\\n\\n\\n\\n\\n\\nXFL\\n\\n\\n\\n\\n\\n\\n\\nMLB: Select Games\\n\\n\\n\\n\\n\\n\\n\\nNCAA Baseball\\n\\n\\n\\n\\n\\n\\n\\nNCAA Softball\\n\\n\\n\\n\\n\\n\\n\\nCricket: Select Matches\\n\\n\\n\\n\\n\\n\\n\\nMel Kiper's NFL Mock Draft 3.0\\n\\n\\nQuick Links\\n\\n\\n\\n\\nMen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nWomen's Tournament Challenge\\n\\n\\n\\n\\n\\n\\n\\nNFL Draft Order\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch NHL Games\\n\\n\\n\\n\\n\\n\\n\\nFantasy Baseball: Sign Up\\n\\n\\n\\n\\n\\n\\n\\nHow To Watch PGA TOUR\\n\\n\\nESPN Sites\\n\\n\\n\\n\\nESPN Deportes\\n\\n\\n\\n\\n\\n\\n\\nAndscape\\n\\n\\n\\n\\n\\n\\n\\nespnW\\n\\n\\n\\n\\n\\n\\n\\nESPNFC\\n\\n\\n\\n\\n\\n\\n\\nX Games\\n\\n\\n\\n\\n\\n\\n\\nSEC Network\\n\\n\\nESPN Apps\\n\\n\\n\\n\\nESPN\\n\\n\\n\\n\\n\\n\\n\\nESPN Fantasy\\n\\n\\nFollow ESPN\\n\\n\\n\\n\\nFacebook\\n\\n\\n\\n\\n\\n\\n\\nTwitter\\n\\n\\n\\n\\n\\n\\n\\nInstagram\\n\\n\\n\\n\\n\\n\\n\\nSnapchat\\n\\n\\n\\n\\n\\n\\n\\nYouTube\\n\\n\\n\\n\\n\\n\\n\\nThe ESPN Daily Podcast\\n\\n\\nTerms of UsePrivacy PolicyYour US State Privacy RightsChildren's Online Privacy PolicyInterest-Based AdsAbout Nielsen MeasurementDo Not Sell or Share My Personal InformationContact UsDisney Ad Sales SiteWork for ESPNCopyright: © ESPN Enterprises, Inc. All rights reserved.\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\\n\", lookup_str='', metadata={'source': 'https://www.espn.com/'}, lookup_index=0),\n", + " Document(page_content='GoogleSearch Images Maps Play YouTube News Gmail Drive More »Web History | Settings | Sign in\\xa0Advanced searchAdvertisingBusiness SolutionsAbout Google© 2023 - Privacy - Terms ', lookup_str='', metadata={'source': 'https://google.com'}, lookup_index=0)]" ] - }, + }, + "execution_count": 10, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "loader = WebBaseLoader([\"https://www.espn.com/\", \"https://google.com\"])\n", + "loader.requests_per_second = 1\n", + "docs = loader.aload()\n", + "docs" + ] + }, + { + "cell_type": "markdown", + "id": "e337b130", + "metadata": {}, + "source": [ + "## Loading a xml file, or using a different BeautifulSoup parser\n", + "\n", + "You can also look at `SitemapLoader` for an example of how to load a sitemap file, which is an example of using this feature." + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "id": "16530c50", + "metadata": {}, + "outputs": [ { - "cell_type": "code", - "execution_count": 2, - "id": "16530c50", - "metadata": {}, - "outputs": [ - { - "data": { - "text/plain": [ - "[Document(page_content='\\n\\n10\\nEnergy\\n3\\n2018-01-01\\n2018-01-01\\nfalse\\nUniform test method for the measurement of energy efficiency of commercial packaged boilers.\\n\u00c2\u00a7 431.86\\nSection \u00c2\u00a7 431.86\\n\\nEnergy\\nDEPARTMENT OF ENERGY\\nENERGY CONSERVATION\\nENERGY EFFICIENCY PROGRAM FOR CERTAIN COMMERCIAL AND INDUSTRIAL EQUIPMENT\\nCommercial Packaged Boilers\\nTest Procedures\\n\\n\\n\\n\\n\u00a7\\u2009431.86\\nUniform test method for the measurement of energy efficiency of commercial packaged boilers.\\n(a) Scope. This section provides test procedures, pursuant to the Energy Policy and Conservation Act (EPCA), as amended, which must be followed for measuring the combustion efficiency and/or thermal efficiency of a gas- or oil-fired commercial packaged boiler.\\n(b) Testing and Calculations. Determine the thermal efficiency or combustion efficiency of commercial packaged boilers by conducting the appropriate test procedure(s) indicated in Table 1 of this section.\\n\\nTable 1\u2014Test Requirements for Commercial Packaged Boiler Equipment Classes\\n\\nEquipment category\\nSubcategory\\nCertified rated inputBtu/h\\n\\nStandards efficiency metric(\u00a7\\u2009431.87)\\n\\nTest procedure(corresponding to\\nstandards efficiency\\nmetric required\\nby \u00a7\\u2009431.87)\\n\\n\\n\\nHot Water\\nGas-fired\\n\u2265300,000 and \u22642,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nHot Water\\nGas-fired\\n>2,500,000\\nCombustion Efficiency\\nAppendix A, Section 3.\\n\\n\\nHot Water\\nOil-fired\\n\u2265300,000 and \u22642,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nHot Water\\nOil-fired\\n>2,500,000\\nCombustion Efficiency\\nAppendix A, Section 3.\\n\\n\\nSteam\\nGas-fired (all*)\\n\u2265300,000 and \u22642,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nSteam\\nGas-fired (all*)\\n>2,500,000 and \u22645,000,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\n\\u2003\\n\\n>5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.OR\\nAppendix A, Section 3 with Section 2.4.3.2.\\n\\n\\n\\nSteam\\nOil-fired\\n\u2265300,000 and \u22642,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nSteam\\nOil-fired\\n>2,500,000 and \u22645,000,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\n\\u2003\\n\\n>5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.OR\\nAppendix A, Section 3. with Section 2.4.3.2.\\n\\n\\n\\n*\\u2009Equipment classes for commercial packaged boilers as of July 22, 2009 (74 FR 36355) distinguish between gas-fired natural draft and all other gas-fired (except natural draft).\\n\\n(c) Field Tests. The field test provisions of appendix A may be used only to test a unit of commercial packaged boiler with rated input greater than 5,000,000 Btu/h.\\n[81 FR 89305, Dec. 9, 2016]\\n\\n\\nEnergy Efficiency Standards\\n\\n', lookup_str='', metadata={'source': 'https://www.govinfo.gov/content/pkg/CFR-2018-title10-vol3/xml/CFR-2018-title10-vol3-sec431-86.xml'}, lookup_index=0)]" - ] - }, - "execution_count": 2, - "metadata": {}, - "output_type": "execute_result" - } - ], - "source": [ - "loader = WebBaseLoader(\n", - " \"https://www.govinfo.gov/content/pkg/CFR-2018-title10-vol3/xml/CFR-2018-title10-vol3-sec431-86.xml\"\n", - ")\n", - "loader.default_parser = \"xml\"\n", - "docs = loader.load()\n", - "docs" + "data": { + "text/plain": [ + "[Document(page_content='\\n\\n10\\nEnergy\\n3\\n2018-01-01\\n2018-01-01\\nfalse\\nUniform test method for the measurement of energy efficiency of commercial packaged boilers.\\n§ 431.86\\nSection § 431.86\\n\\nEnergy\\nDEPARTMENT OF ENERGY\\nENERGY CONSERVATION\\nENERGY EFFICIENCY PROGRAM FOR CERTAIN COMMERCIAL AND INDUSTRIAL EQUIPMENT\\nCommercial Packaged Boilers\\nTest Procedures\\n\\n\\n\\n\\n§\\u2009431.86\\nUniform test method for the measurement of energy efficiency of commercial packaged boilers.\\n(a) Scope. This section provides test procedures, pursuant to the Energy Policy and Conservation Act (EPCA), as amended, which must be followed for measuring the combustion efficiency and/or thermal efficiency of a gas- or oil-fired commercial packaged boiler.\\n(b) Testing and Calculations. Determine the thermal efficiency or combustion efficiency of commercial packaged boilers by conducting the appropriate test procedure(s) indicated in Table 1 of this section.\\n\\nTable 1—Test Requirements for Commercial Packaged Boiler Equipment Classes\\n\\nEquipment category\\nSubcategory\\nCertified rated inputBtu/h\\n\\nStandards efficiency metric(§\\u2009431.87)\\n\\nTest procedure(corresponding to\\nstandards efficiency\\nmetric required\\nby §\\u2009431.87)\\n\\n\\n\\nHot Water\\nGas-fired\\n≥300,000 and ≤2,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nHot Water\\nGas-fired\\n>2,500,000\\nCombustion Efficiency\\nAppendix A, Section 3.\\n\\n\\nHot Water\\nOil-fired\\n≥300,000 and ≤2,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nHot Water\\nOil-fired\\n>2,500,000\\nCombustion Efficiency\\nAppendix A, Section 3.\\n\\n\\nSteam\\nGas-fired (all*)\\n≥300,000 and ≤2,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nSteam\\nGas-fired (all*)\\n>2,500,000 and ≤5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\n\\u2003\\n\\n>5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.OR\\nAppendix A, Section 3 with Section 2.4.3.2.\\n\\n\\n\\nSteam\\nOil-fired\\n≥300,000 and ≤2,500,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\nSteam\\nOil-fired\\n>2,500,000 and ≤5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.\\n\\n\\n\\u2003\\n\\n>5,000,000\\nThermal Efficiency\\nAppendix A, Section 2.OR\\nAppendix A, Section 3. with Section 2.4.3.2.\\n\\n\\n\\n*\\u2009Equipment classes for commercial packaged boilers as of July 22, 2009 (74 FR 36355) distinguish between gas-fired natural draft and all other gas-fired (except natural draft).\\n\\n(c) Field Tests. The field test provisions of appendix A may be used only to test a unit of commercial packaged boiler with rated input greater than 5,000,000 Btu/h.\\n[81 FR 89305, Dec. 9, 2016]\\n\\n\\nEnergy Efficiency Standards\\n\\n', lookup_str='', metadata={'source': 'https://www.govinfo.gov/content/pkg/CFR-2018-title10-vol3/xml/CFR-2018-title10-vol3-sec431-86.xml'}, lookup_index=0)]" ] - }, - { - "cell_type": "markdown", - "source": [ - "## Using proxies\n", - "\n", - "Sometimes you might need to use proxies to get around IP blocks. You can pass in a dictionary of proxies to the loader (and `requests` underneath) to use them." - ], - "metadata": { - "collapsed": false - }, - "id": "672264ad" - }, - { - "cell_type": "code", - "execution_count": null, - "outputs": [], - "source": [ - "loader = WebBaseLoader(\n", - " \"https://www.walmart.com/search?q=parrots\", proxies={\n", - " \"http\": \"http://{username}:{password}:@proxy.service.com:6666/\",\n", - " \"https\": \"https://{username}:{password}:@proxy.service.com:6666/\"\n", - " }\n", - ")\n", - "docs = loader.load()\n" - ], - "metadata": { - "collapsed": false - }, - "id": "9caf0310" - } - ], - "metadata": { - "kernelspec": { - "display_name": "Python 3 (ipykernel)", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.10.6" + }, + "execution_count": 2, + "metadata": {}, + "output_type": "execute_result" } + ], + "source": [ + "loader = WebBaseLoader(\n", + " \"https://www.govinfo.gov/content/pkg/CFR-2018-title10-vol3/xml/CFR-2018-title10-vol3-sec431-86.xml\"\n", + ")\n", + "loader.default_parser = \"xml\"\n", + "docs = loader.load()\n", + "docs" + ] + }, + { + "cell_type": "markdown", + "source": [ + "## Using proxies\n", + "\n", + "Sometimes you might need to use proxies to get around IP blocks. You can pass in a dictionary of proxies to the loader (and `requests` underneath) to use them." + ], + "metadata": { + "collapsed": false + }, + "id": "672264ad" + }, + { + "cell_type": "code", + "execution_count": null, + "outputs": [], + "source": [ + "loader = WebBaseLoader(\n", + " \"https://www.walmart.com/search?q=parrots\",\n", + " proxies={\n", + " \"http\": \"http://{username}:{password}:@proxy.service.com:6666/\",\n", + " \"https\": \"https://{username}:{password}:@proxy.service.com:6666/\",\n", + " },\n", + ")\n", + "docs = loader.load()" + ], + "metadata": { + "collapsed": false + }, + "id": "9caf0310" + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3 (ipykernel)", + "language": "python", + "name": "python3" }, - "nbformat": 4, - "nbformat_minor": 5 + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.6" + } + }, + "nbformat": 4, + "nbformat_minor": 5 } \ No newline at end of file diff --git a/docs/extras/modules/data_connection/document_transformers/text_splitters/markdown_header_metadata.ipynb b/docs/extras/modules/data_connection/document_transformers/text_splitters/markdown_header_metadata.ipynb index 860a897769615..88c89cd121197 100644 --- a/docs/extras/modules/data_connection/document_transformers/text_splitters/markdown_header_metadata.ipynb +++ b/docs/extras/modules/data_connection/document_transformers/text_splitters/markdown_header_metadata.ipynb @@ -155,9 +155,12 @@ "\n", "# Char-level splits\n", "from langchain.text_splitter import RecursiveCharacterTextSplitter\n", + "\n", "chunk_size = 250\n", "chunk_overlap = 30\n", - "text_splitter = RecursiveCharacterTextSplitter(chunk_size=chunk_size, chunk_overlap=chunk_overlap)\n", + "text_splitter = RecursiveCharacterTextSplitter(\n", + " chunk_size=chunk_size, chunk_overlap=chunk_overlap\n", + ")\n", "\n", "# Split\n", "splits = text_splitter.split_documents(md_header_splits)\n", diff --git a/docs/extras/modules/data_connection/retrievers/how_to/MultiQueryRetriever.ipynb b/docs/extras/modules/data_connection/retrievers/how_to/MultiQueryRetriever.ipynb index facbc925a628e..487a412768b68 100644 --- a/docs/extras/modules/data_connection/retrievers/how_to/MultiQueryRetriever.ipynb +++ b/docs/extras/modules/data_connection/retrievers/how_to/MultiQueryRetriever.ipynb @@ -28,14 +28,14 @@ "# Load blog post\n", "loader = WebBaseLoader(\"https://lilianweng.github.io/posts/2023-06-23-agent/\")\n", "data = loader.load()\n", - " \n", + "\n", "# Split\n", - "text_splitter = RecursiveCharacterTextSplitter(chunk_size = 500, chunk_overlap = 0)\n", + "text_splitter = RecursiveCharacterTextSplitter(chunk_size=500, chunk_overlap=0)\n", "splits = text_splitter.split_documents(data)\n", "\n", "# VectorDB\n", "embedding = OpenAIEmbeddings()\n", - "vectordb = Chroma.from_documents(documents=splits,embedding=embedding)" + "vectordb = Chroma.from_documents(documents=splits, embedding=embedding)" ] }, { @@ -57,9 +57,12 @@ "source": [ "from langchain.chat_models import ChatOpenAI\n", "from langchain.retrievers.multi_query import MultiQueryRetriever\n", - "question=\"What are the approaches to Task Decomposition?\"\n", + "\n", + "question = \"What are the approaches to Task Decomposition?\"\n", "llm = ChatOpenAI(temperature=0)\n", - "retriever_from_llm = MultiQueryRetriever.from_llm(retriever=vectordb.as_retriever(),llm=llm)" + "retriever_from_llm = MultiQueryRetriever.from_llm(\n", + " retriever=vectordb.as_retriever(), llm=llm\n", + ")" ] }, { @@ -71,8 +74,9 @@ "source": [ "# Set logging for the queries\n", "import logging\n", + "\n", "logging.basicConfig()\n", - "logging.getLogger('langchain.retrievers.multi_query').setLevel(logging.INFO)" + "logging.getLogger(\"langchain.retrievers.multi_query\").setLevel(logging.INFO)" ] }, { @@ -127,20 +131,24 @@ "from langchain.prompts import PromptTemplate\n", "from langchain.output_parsers import PydanticOutputParser\n", "\n", + "\n", "# Output parser will split the LLM result into a list of queries\n", "class LineList(BaseModel):\n", " # \"lines\" is the key (attribute name) of the parsed output\n", " lines: List[str] = Field(description=\"Lines of text\")\n", "\n", + "\n", "class LineListOutputParser(PydanticOutputParser):\n", " def __init__(self) -> None:\n", " super().__init__(pydantic_object=LineList)\n", + "\n", " def parse(self, text: str) -> LineList:\n", " lines = text.strip().split(\"\\n\")\n", " return LineList(lines=lines)\n", "\n", + "\n", "output_parser = LineListOutputParser()\n", - " \n", + "\n", "QUERY_PROMPT = PromptTemplate(\n", " input_variables=[\"question\"],\n", " template=\"\"\"You are an AI language model assistant. Your task is to generate five \n", @@ -153,10 +161,10 @@ "llm = ChatOpenAI(temperature=0)\n", "\n", "# Chain\n", - "llm_chain = LLMChain(llm=llm,prompt=QUERY_PROMPT,output_parser=output_parser)\n", - " \n", + "llm_chain = LLMChain(llm=llm, prompt=QUERY_PROMPT, output_parser=output_parser)\n", + "\n", "# Other inputs\n", - "question=\"What are the approaches to Task Decomposition?\"" + "question = \"What are the approaches to Task Decomposition?\"" ] }, { @@ -185,12 +193,14 @@ ], "source": [ "# Run\n", - "retriever = MultiQueryRetriever(retriever=vectordb.as_retriever(), \n", - " llm_chain=llm_chain,\n", - " parser_key=\"lines\") # \"lines\" is the key (attribute name) of the parsed output\n", + "retriever = MultiQueryRetriever(\n", + " retriever=vectordb.as_retriever(), llm_chain=llm_chain, parser_key=\"lines\"\n", + ") # \"lines\" is the key (attribute name) of the parsed output\n", "\n", "# Results\n", - "unique_docs = retriever.get_relevant_documents(query=\"What does the course say about regression?\")\n", + "unique_docs = retriever.get_relevant_documents(\n", + " query=\"What does the course say about regression?\"\n", + ")\n", "len(unique_docs)" ] } diff --git a/docs/extras/modules/data_connection/retrievers/how_to/self_query/myscale_self_query.ipynb b/docs/extras/modules/data_connection/retrievers/how_to/self_query/myscale_self_query.ipynb index fd07ffe02f02a..160db7c0204c6 100644 --- a/docs/extras/modules/data_connection/retrievers/how_to/self_query/myscale_self_query.ipynb +++ b/docs/extras/modules/data_connection/retrievers/how_to/self_query/myscale_self_query.ipynb @@ -59,11 +59,11 @@ "import os\n", "import getpass\n", "\n", - "os.environ['OPENAI_API_KEY'] = getpass.getpass('OpenAI API Key:')\n", - "os.environ['MYSCALE_HOST'] = getpass.getpass('MyScale URL:')\n", - "os.environ['MYSCALE_PORT'] = getpass.getpass('MyScale Port:')\n", - "os.environ['MYSCALE_USERNAME'] = getpass.getpass('MyScale Username:')\n", - "os.environ['MYSCALE_PASSWORD'] = getpass.getpass('MyScale Password:')" + "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")\n", + "os.environ[\"MYSCALE_HOST\"] = getpass.getpass(\"MyScale URL:\")\n", + "os.environ[\"MYSCALE_PORT\"] = getpass.getpass(\"MyScale Port:\")\n", + "os.environ[\"MYSCALE_USERNAME\"] = getpass.getpass(\"MyScale Username:\")\n", + "os.environ[\"MYSCALE_PASSWORD\"] = getpass.getpass(\"MyScale Password:\")" ] }, { @@ -103,16 +103,40 @@ "outputs": [], "source": [ "docs = [\n", - " Document(page_content=\"A bunch of scientists bring back dinosaurs and mayhem breaks loose\", metadata={\"date\": \"1993-07-02\", \"rating\": 7.7, \"genre\": [\"science fiction\"]}),\n", - " Document(page_content=\"Leo DiCaprio gets lost in a dream within a dream within a dream within a ...\", metadata={\"date\": \"2010-12-30\", \"director\": \"Christopher Nolan\", \"rating\": 8.2}),\n", - " Document(page_content=\"A psychologist / detective gets lost in a series of dreams within dreams within dreams and Inception reused the idea\", metadata={\"date\": \"2006-04-23\", \"director\": \"Satoshi Kon\", \"rating\": 8.6}),\n", - " Document(page_content=\"A bunch of normal-sized women are supremely wholesome and some men pine after them\", metadata={\"date\": \"2019-08-22\", \"director\": \"Greta Gerwig\", \"rating\": 8.3}),\n", - " Document(page_content=\"Toys come alive and have a blast doing so\", metadata={\"date\": \"1995-02-11\", \"genre\": [\"animated\"]}),\n", - " Document(page_content=\"Three men walk into the Zone, three men walk out of the Zone\", metadata={\"date\": \"1979-09-10\", \"rating\": 9.9, \"director\": \"Andrei Tarkovsky\", \"genre\": [\"science fiction\", \"adventure\"], \"rating\": 9.9})\n", + " Document(\n", + " page_content=\"A bunch of scientists bring back dinosaurs and mayhem breaks loose\",\n", + " metadata={\"date\": \"1993-07-02\", \"rating\": 7.7, \"genre\": [\"science fiction\"]},\n", + " ),\n", + " Document(\n", + " page_content=\"Leo DiCaprio gets lost in a dream within a dream within a dream within a ...\",\n", + " metadata={\"date\": \"2010-12-30\", \"director\": \"Christopher Nolan\", \"rating\": 8.2},\n", + " ),\n", + " Document(\n", + " page_content=\"A psychologist / detective gets lost in a series of dreams within dreams within dreams and Inception reused the idea\",\n", + " metadata={\"date\": \"2006-04-23\", \"director\": \"Satoshi Kon\", \"rating\": 8.6},\n", + " ),\n", + " Document(\n", + " page_content=\"A bunch of normal-sized women are supremely wholesome and some men pine after them\",\n", + " metadata={\"date\": \"2019-08-22\", \"director\": \"Greta Gerwig\", \"rating\": 8.3},\n", + " ),\n", + " Document(\n", + " page_content=\"Toys come alive and have a blast doing so\",\n", + " metadata={\"date\": \"1995-02-11\", \"genre\": [\"animated\"]},\n", + " ),\n", + " Document(\n", + " page_content=\"Three men walk into the Zone, three men walk out of the Zone\",\n", + " metadata={\n", + " \"date\": \"1979-09-10\",\n", + " \"rating\": 9.9,\n", + " \"director\": \"Andrei Tarkovsky\",\n", + " \"genre\": [\"science fiction\", \"adventure\"],\n", + " \"rating\": 9.9,\n", + " },\n", + " ),\n", "]\n", "vectorstore = MyScale.from_documents(\n", - " docs, \n", - " embeddings, \n", + " docs,\n", + " embeddings,\n", ")" ] }, @@ -138,39 +162,39 @@ "from langchain.retrievers.self_query.base import SelfQueryRetriever\n", "from langchain.chains.query_constructor.base import AttributeInfo\n", "\n", - "metadata_field_info=[\n", + "metadata_field_info = [\n", " AttributeInfo(\n", " name=\"genre\",\n", - " description=\"The genres of the movie\", \n", - " type=\"list[string]\", \n", + " description=\"The genres of the movie\",\n", + " type=\"list[string]\",\n", " ),\n", " # If you want to include length of a list, just define it as a new column\n", " # This will teach the LLM to use it as a column when constructing filter.\n", " AttributeInfo(\n", " name=\"length(genre)\",\n", - " description=\"The length of genres of the movie\", \n", - " type=\"integer\", \n", + " description=\"The length of genres of the movie\",\n", + " type=\"integer\",\n", " ),\n", " # Now you can define a column as timestamp. By simply set the type to timestamp.\n", " AttributeInfo(\n", " name=\"date\",\n", - " description=\"The date the movie was released\", \n", - " type=\"timestamp\", \n", + " description=\"The date the movie was released\",\n", + " type=\"timestamp\",\n", " ),\n", " AttributeInfo(\n", " name=\"director\",\n", - " description=\"The name of the movie director\", \n", - " type=\"string\", \n", + " description=\"The name of the movie director\",\n", + " type=\"string\",\n", " ),\n", " AttributeInfo(\n", - " name=\"rating\",\n", - " description=\"A 1-10 rating for the movie\",\n", - " type=\"float\"\n", + " name=\"rating\", description=\"A 1-10 rating for the movie\", type=\"float\"\n", " ),\n", "]\n", "document_content_description = \"Brief summary of a movie\"\n", "llm = OpenAI(temperature=0)\n", - "retriever = SelfQueryRetriever.from_llm(llm, vectorstore, document_content_description, metadata_field_info, verbose=True)" + "retriever = SelfQueryRetriever.from_llm(\n", + " llm, vectorstore, document_content_description, metadata_field_info, verbose=True\n", + ")" ] }, { @@ -225,7 +249,9 @@ "outputs": [], "source": [ "# This example specifies a composite filter\n", - "retriever.get_relevant_documents(\"What's a highly rated (above 8.5) science fiction film?\")" + "retriever.get_relevant_documents(\n", + " \"What's a highly rated (above 8.5) science fiction film?\"\n", + ")" ] }, { @@ -236,7 +262,9 @@ "outputs": [], "source": [ "# This example specifies a query and composite filter\n", - "retriever.get_relevant_documents(\"What's a movie after 1990 but before 2005 that's all about toys, and preferably is animated\")" + "retriever.get_relevant_documents(\n", + " \"What's a movie after 1990 but before 2005 that's all about toys, and preferably is animated\"\n", + ")" ] }, { @@ -290,7 +318,9 @@ "outputs": [], "source": [ "# Contain works for lists: so you can match a list with contain comparator!\n", - "retriever.get_relevant_documents(\"What's a movie who has genres science fiction and adventure?\")" + "retriever.get_relevant_documents(\n", + " \"What's a movie who has genres science fiction and adventure?\"\n", + ")" ] }, { @@ -315,12 +345,12 @@ "outputs": [], "source": [ "retriever = SelfQueryRetriever.from_llm(\n", - " llm, \n", - " vectorstore, \n", - " document_content_description, \n", - " metadata_field_info, \n", + " llm,\n", + " vectorstore,\n", + " document_content_description,\n", + " metadata_field_info,\n", " enable_limit=True,\n", - " verbose=True\n", + " verbose=True,\n", ")" ] }, diff --git a/docs/extras/modules/data_connection/retrievers/integrations/amazon_kendra_retriever.ipynb b/docs/extras/modules/data_connection/retrievers/integrations/amazon_kendra_retriever.ipynb index f734f0aec774f..75cd9372a9df9 100644 --- a/docs/extras/modules/data_connection/retrievers/integrations/amazon_kendra_retriever.ipynb +++ b/docs/extras/modules/data_connection/retrievers/integrations/amazon_kendra_retriever.ipynb @@ -53,9 +53,7 @@ "metadata": {}, "outputs": [], "source": [ - "retriever = AmazonKendraRetriever(\n", - " index_id=\"c0806df7-e76b-4bce-9b5c-d5582f6b1a03\"\n", - ")" + "retriever = AmazonKendraRetriever(index_id=\"c0806df7-e76b-4bce-9b5c-d5582f6b1a03\")" ] }, { diff --git a/docs/extras/modules/data_connection/retrievers/integrations/docarray_retriever.ipynb b/docs/extras/modules/data_connection/retrievers/integrations/docarray_retriever.ipynb index a3462753df893..1cfb4189ae8f9 100644 --- a/docs/extras/modules/data_connection/retrievers/integrations/docarray_retriever.ipynb +++ b/docs/extras/modules/data_connection/retrievers/integrations/docarray_retriever.ipynb @@ -111,10 +111,10 @@ "db.index(\n", " [\n", " MyDoc(\n", - " title=f'My document {i}',\n", - " title_embedding=embeddings.embed_query(f'query {i}'),\n", + " title=f\"My document {i}\",\n", + " title_embedding=embeddings.embed_query(f\"query {i}\"),\n", " year=i,\n", - " color=random.choice(['red', 'green', 'blue']),\n", + " color=random.choice([\"red\", \"green\", \"blue\"]),\n", " )\n", " for i in range(100)\n", " ]\n", @@ -142,15 +142,15 @@ "source": [ "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='title_embedding', \n", - " content_field='title',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"title_embedding\",\n", + " content_field=\"title\",\n", " filters=filter_query,\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('some query')\n", + "doc = retriever.get_relevant_documents(\"some query\")\n", "print(doc)" ] }, @@ -179,16 +179,16 @@ "\n", "\n", "# initialize the index\n", - "db = HnswDocumentIndex[MyDoc](work_dir='hnsw_index')\n", + "db = HnswDocumentIndex[MyDoc](work_dir=\"hnsw_index\")\n", "\n", "# index data\n", "db.index(\n", " [\n", " MyDoc(\n", - " title=f'My document {i}',\n", - " title_embedding=embeddings.embed_query(f'query {i}'),\n", + " title=f\"My document {i}\",\n", + " title_embedding=embeddings.embed_query(f\"query {i}\"),\n", " year=i,\n", - " color=random.choice(['red', 'green', 'blue']),\n", + " color=random.choice([\"red\", \"green\", \"blue\"]),\n", " )\n", " for i in range(100)\n", " ]\n", @@ -216,15 +216,15 @@ "source": [ "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='title_embedding', \n", - " content_field='title',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"title_embedding\",\n", + " content_field=\"title\",\n", " filters=filter_query,\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('some query')\n", + "doc = retriever.get_relevant_documents(\"some query\")\n", "print(doc)" ] }, @@ -249,11 +249,12 @@ }, "outputs": [], "source": [ - "# There's a small difference with the Weaviate backend compared to the others. \n", - "# Here, you need to 'mark' the field used for vector search with 'is_embedding=True'. \n", + "# There's a small difference with the Weaviate backend compared to the others.\n", + "# Here, you need to 'mark' the field used for vector search with 'is_embedding=True'.\n", "# So, let's create a new schema for Weaviate that takes care of this requirement.\n", "\n", - "from pydantic import Field \n", + "from pydantic import Field\n", + "\n", "\n", "class WeaviateDoc(BaseDoc):\n", " title: str\n", @@ -275,19 +276,17 @@ "\n", "\n", "# initialize the index\n", - "dbconfig = WeaviateDocumentIndex.DBConfig(\n", - " host=\"http://localhost:8080\"\n", - ")\n", + "dbconfig = WeaviateDocumentIndex.DBConfig(host=\"http://localhost:8080\")\n", "db = WeaviateDocumentIndex[WeaviateDoc](db_config=dbconfig)\n", "\n", "# index data\n", "db.index(\n", " [\n", " MyDoc(\n", - " title=f'My document {i}',\n", - " title_embedding=embeddings.embed_query(f'query {i}'),\n", + " title=f\"My document {i}\",\n", + " title_embedding=embeddings.embed_query(f\"query {i}\"),\n", " year=i,\n", - " color=random.choice(['red', 'green', 'blue']),\n", + " color=random.choice([\"red\", \"green\", \"blue\"]),\n", " )\n", " for i in range(100)\n", " ]\n", @@ -315,15 +314,15 @@ "source": [ "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='title_embedding', \n", - " content_field='title',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"title_embedding\",\n", + " content_field=\"title\",\n", " filters=filter_query,\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('some query')\n", + "doc = retriever.get_relevant_documents(\"some query\")\n", "print(doc)" ] }, @@ -353,18 +352,17 @@ "\n", "# initialize the index\n", "db = ElasticDocIndex[MyDoc](\n", - " hosts=\"http://localhost:9200\", \n", - " index_name=\"docarray_retriever\"\n", + " hosts=\"http://localhost:9200\", index_name=\"docarray_retriever\"\n", ")\n", "\n", "# index data\n", "db.index(\n", " [\n", " MyDoc(\n", - " title=f'My document {i}',\n", - " title_embedding=embeddings.embed_query(f'query {i}'),\n", + " title=f\"My document {i}\",\n", + " title_embedding=embeddings.embed_query(f\"query {i}\"),\n", " year=i,\n", - " color=random.choice(['red', 'green', 'blue']),\n", + " color=random.choice([\"red\", \"green\", \"blue\"]),\n", " )\n", " for i in range(100)\n", " ]\n", @@ -392,15 +390,15 @@ "source": [ "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='title_embedding', \n", - " content_field='title',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"title_embedding\",\n", + " content_field=\"title\",\n", " filters=filter_query,\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('some query')\n", + "doc = retriever.get_relevant_documents(\"some query\")\n", "print(doc)" ] }, @@ -445,10 +443,10 @@ "db.index(\n", " [\n", " MyDoc(\n", - " title=f'My document {i}',\n", - " title_embedding=embeddings.embed_query(f'query {i}'),\n", + " title=f\"My document {i}\",\n", + " title_embedding=embeddings.embed_query(f\"query {i}\"),\n", " year=i,\n", - " color=random.choice(['red', 'green', 'blue']),\n", + " color=random.choice([\"red\", \"green\", \"blue\"]),\n", " )\n", " for i in range(100)\n", " ]\n", @@ -486,15 +484,15 @@ "source": [ "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='title_embedding', \n", - " content_field='title',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"title_embedding\",\n", + " content_field=\"title\",\n", " filters=filter_query,\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('some query')\n", + "doc = retriever.get_relevant_documents(\"some query\")\n", "print(doc)" ] }, @@ -552,7 +550,7 @@ " \"director\": \"Francis Ford Coppola\",\n", " \"rating\": 9.2,\n", " },\n", - "]\n" + "]" ] }, { @@ -573,9 +571,9 @@ ], "source": [ "import getpass\n", - "import os \n", + "import os\n", "\n", - "os.environ['OPENAI_API_KEY'] = getpass.getpass('OpenAI API Key:')" + "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")" ] }, { @@ -591,6 +589,7 @@ "from docarray.typing import NdArray\n", "from langchain.embeddings.openai import OpenAIEmbeddings\n", "\n", + "\n", "# define schema for your movie documents\n", "class MyDoc(BaseDoc):\n", " title: str\n", @@ -598,7 +597,7 @@ " description_embedding: NdArray[1536]\n", " rating: float\n", " director: str\n", - " \n", + "\n", "\n", "embeddings = OpenAIEmbeddings()\n", "\n", @@ -626,7 +625,7 @@ "from docarray.index import HnswDocumentIndex\n", "\n", "# initialize the index\n", - "db = HnswDocumentIndex[MyDoc](work_dir='movie_search')\n", + "db = HnswDocumentIndex[MyDoc](work_dir=\"movie_search\")\n", "\n", "# add data\n", "db.index(docs)" @@ -663,14 +662,14 @@ "\n", "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='description_embedding', \n", - " content_field='description'\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"description_embedding\",\n", + " content_field=\"description\",\n", ")\n", "\n", "# find the relevant document\n", - "doc = retriever.get_relevant_documents('movie about dreams')\n", + "doc = retriever.get_relevant_documents(\"movie about dreams\")\n", "print(doc)" ] }, @@ -703,16 +702,16 @@ "\n", "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='description_embedding', \n", - " content_field='description',\n", - " filters={'director': {'$eq': 'Christopher Nolan'}},\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"description_embedding\",\n", + " content_field=\"description\",\n", + " filters={\"director\": {\"$eq\": \"Christopher Nolan\"}},\n", " top_k=2,\n", ")\n", "\n", "# find relevant documents\n", - "docs = retriever.get_relevant_documents('space travel')\n", + "docs = retriever.get_relevant_documents(\"space travel\")\n", "print(docs)" ] }, @@ -745,17 +744,17 @@ "\n", "# create a retriever\n", "retriever = DocArrayRetriever(\n", - " index=db, \n", - " embeddings=embeddings, \n", - " search_field='description_embedding', \n", - " content_field='description',\n", - " filters={'rating': {'$gte': 8.7}},\n", - " search_type='mmr',\n", + " index=db,\n", + " embeddings=embeddings,\n", + " search_field=\"description_embedding\",\n", + " content_field=\"description\",\n", + " filters={\"rating\": {\"$gte\": 8.7}},\n", + " search_type=\"mmr\",\n", " top_k=3,\n", ")\n", "\n", "# find relevant documents\n", - "docs = retriever.get_relevant_documents('action movies')\n", + "docs = retriever.get_relevant_documents(\"action movies\")\n", "print(docs)" ] }, diff --git a/docs/extras/modules/data_connection/retrievers/integrations/merger_retriever.ipynb b/docs/extras/modules/data_connection/retrievers/integrations/merger_retriever.ipynb index 98e4fa39fc9ed..e553442916c68 100644 --- a/docs/extras/modules/data_connection/retrievers/integrations/merger_retriever.ipynb +++ b/docs/extras/modules/data_connection/retrievers/integrations/merger_retriever.ipynb @@ -26,7 +26,10 @@ "from langchain.vectorstores import Chroma\n", "from langchain.embeddings import HuggingFaceEmbeddings\n", "from langchain.embeddings import OpenAIEmbeddings\n", - "from langchain.document_transformers import EmbeddingsRedundantFilter,EmbeddingsClusteringFilter\n", + "from langchain.document_transformers import (\n", + " EmbeddingsRedundantFilter,\n", + " EmbeddingsClusteringFilter,\n", + ")\n", "from langchain.retrievers.document_compressors import DocumentCompressorPipeline\n", "from langchain.retrievers import ContextualCompressionRetriever\n", "\n", @@ -115,24 +118,24 @@ "# Then it will pick the closest document to that center for the final results.\n", "# By default the result document will be ordered/grouped by clusters.\n", "filter_ordered_cluster = EmbeddingsClusteringFilter(\n", - " embeddings=filter_embeddings,\n", - " num_clusters=10,\n", - " num_closest=1,\n", - " )\n", + " embeddings=filter_embeddings,\n", + " num_clusters=10,\n", + " num_closest=1,\n", + ")\n", "\n", "# If you want the final document to be ordered by the original retriever scores\n", "# you need to add the \"sorted\" parameter.\n", "filter_ordered_by_retriever = EmbeddingsClusteringFilter(\n", - " embeddings=filter_embeddings,\n", - " num_clusters=10,\n", - " num_closest=1,\n", - " sorted = True,\n", - " )\n", + " embeddings=filter_embeddings,\n", + " num_clusters=10,\n", + " num_closest=1,\n", + " sorted=True,\n", + ")\n", "\n", "pipeline = DocumentCompressorPipeline(transformers=[filter_ordered_by_retriever])\n", "compression_retriever = ContextualCompressionRetriever(\n", " base_compressor=pipeline, base_retriever=lotr\n", - ")\n" + ")" ] } ], diff --git a/docs/extras/modules/data_connection/retrievers/integrations/zep_memorystore.ipynb b/docs/extras/modules/data_connection/retrievers/integrations/zep_memorystore.ipynb index ed0df2ece4bda..5e77711f50963 100644 --- a/docs/extras/modules/data_connection/retrievers/integrations/zep_memorystore.ipynb +++ b/docs/extras/modules/data_connection/retrievers/integrations/zep_memorystore.ipynb @@ -111,9 +111,7 @@ "\n", "# Set up Zep Chat History. We'll use this to add chat histories to the memory store\n", "zep_chat_history = ZepChatMessageHistory(\n", - " session_id=session_id,\n", - " url=ZEP_API_URL,\n", - " api_key=zep_api_key\n", + " session_id=session_id, url=ZEP_API_URL, api_key=zep_api_key\n", ")" ] }, @@ -247,7 +245,7 @@ " session_id=session_id, # Ensure that you provide the session_id when instantiating the Retriever\n", " url=ZEP_API_URL,\n", " top_k=5,\n", - " api_key=zep_api_key\n", + " api_key=zep_api_key,\n", ")\n", "\n", "await zep_retriever.aget_relevant_documents(\"Who wrote Parable of the Sower?\")" diff --git a/docs/extras/modules/data_connection/text_embedding/integrations/clarifai.ipynb b/docs/extras/modules/data_connection/text_embedding/integrations/clarifai.ipynb index cf79bc30fa5a9..cbd4761c54f4d 100644 --- a/docs/extras/modules/data_connection/text_embedding/integrations/clarifai.ipynb +++ b/docs/extras/modules/data_connection/text_embedding/integrations/clarifai.ipynb @@ -65,7 +65,7 @@ } ], "source": [ - "# Please login and get your API key from https://clarifai.com/settings/security \n", + "# Please login and get your API key from https://clarifai.com/settings/security\n", "from getpass import getpass\n", "\n", "CLARIFAI_PAT = getpass()" @@ -130,9 +130,9 @@ "metadata": {}, "outputs": [], "source": [ - "USER_ID = 'openai'\n", - "APP_ID = 'embed'\n", - "MODEL_ID = 'text-embedding-ada'\n", + "USER_ID = \"openai\"\n", + "APP_ID = \"embed\"\n", + "MODEL_ID = \"text-embedding-ada\"\n", "\n", "# You can provide a specific model version as the model_version_id arg.\n", "# MODEL_VERSION_ID = \"MODEL_VERSION_ID\"" @@ -148,7 +148,9 @@ "outputs": [], "source": [ "# Initialize a Clarifai embedding model\n", - "embeddings = ClarifaiEmbeddings(pat=CLARIFAI_PAT, user_id=USER_ID, app_id=APP_ID, model_id=MODEL_ID)" + "embeddings = ClarifaiEmbeddings(\n", + " pat=CLARIFAI_PAT, user_id=USER_ID, app_id=APP_ID, model_id=MODEL_ID\n", + ")" ] }, { diff --git a/docs/extras/modules/data_connection/text_embedding/integrations/spacy_embedding.ipynb b/docs/extras/modules/data_connection/text_embedding/integrations/spacy_embedding.ipynb index 0e83aaea70104..bfea82d5d4564 100644 --- a/docs/extras/modules/data_connection/text_embedding/integrations/spacy_embedding.ipynb +++ b/docs/extras/modules/data_connection/text_embedding/integrations/spacy_embedding.ipynb @@ -24,10 +24,7 @@ "metadata": {}, "outputs": [], "source": [ - "\n", - "from langchain.embeddings.spacy_embeddings import SpacyEmbeddings\n", - "\n", - "\n" + "from langchain.embeddings.spacy_embeddings import SpacyEmbeddings" ] }, { @@ -44,8 +41,7 @@ "metadata": {}, "outputs": [], "source": [ - "\n", - "embedder = SpacyEmbeddings()\n" + "embedder = SpacyEmbeddings()" ] }, { @@ -62,15 +58,12 @@ "metadata": {}, "outputs": [], "source": [ - "\n", - "\n", "texts = [\n", " \"The quick brown fox jumps over the lazy dog.\",\n", " \"Pack my box with five dozen liquor jugs.\",\n", " \"How vexingly quick daft zebras jump!\",\n", - " \"Bright vixens jump; dozy fowl quack.\"\n", - "]\n", - "\n" + " \"Bright vixens jump; dozy fowl quack.\",\n", + "]" ] }, { @@ -87,11 +80,9 @@ "metadata": {}, "outputs": [], "source": [ - "\n", "embeddings = embedder.embed_documents(texts)\n", "for i, embedding in enumerate(embeddings):\n", - " print(f\"Embedding for document {i+1}: {embedding}\")\n", - "\n" + " print(f\"Embedding for document {i+1}: {embedding}\")" ] }, { @@ -108,7 +99,6 @@ "metadata": {}, "outputs": [], "source": [ - "\n", "query = \"Quick foxes and lazy dogs.\"\n", "query_embedding = embedder.embed_query(query)\n", "print(f\"Embedding for query: {query_embedding}\")" diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/alibabacloud_opensearch.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/alibabacloud_opensearch.ipynb index 871fcd7362d85..759d597bff456 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/alibabacloud_opensearch.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/alibabacloud_opensearch.ipynb @@ -62,7 +62,7 @@ "import os\n", "import getpass\n", "\n", - "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")\n" + "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")" ], "metadata": { "collapsed": false, diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/awadb.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/awadb.ipynb index 93bf1a6d9750d..9760010d8eb3c 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/awadb.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/awadb.ipynb @@ -40,7 +40,7 @@ "metadata": {}, "outputs": [], "source": [ - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=100, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)" @@ -154,10 +154,11 @@ "outputs": [], "source": [ "awadb_client = awadb.Client()\n", - "ret = awadb_client.Load('langchain_awadb')\n", - "if ret : print('awadb load table success')\n", + "ret = awadb_client.Load(\"langchain_awadb\")\n", + "if ret:\n", + " print(\"awadb load table success\")\n", "else:\n", - " print('awadb load table failed')" + " print(\"awadb load table failed\")" ] }, { diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/cassandra.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/cassandra.ipynb index 8d98ecdf1cdad..b689ea74f9a4c 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/cassandra.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/cassandra.ipynb @@ -44,16 +44,18 @@ "import os\n", "import getpass\n", "\n", - "database_mode = (input('\\n(C)assandra or (A)stra DB? ')).upper()\n", + "database_mode = (input(\"\\n(C)assandra or (A)stra DB? \")).upper()\n", "\n", - "keyspace_name = input('\\nKeyspace name? ')\n", + "keyspace_name = input(\"\\nKeyspace name? \")\n", "\n", - "if database_mode == 'A':\n", + "if database_mode == \"A\":\n", " ASTRA_DB_APPLICATION_TOKEN = getpass.getpass('\\nAstra DB Token (\"AstraCS:...\") ')\n", " #\n", - " ASTRA_DB_SECURE_BUNDLE_PATH = input('Full path to your Secure Connect Bundle? ')\n", - "elif database_mode == 'C':\n", - " CASSANDRA_CONTACT_POINTS = input('Contact points? (comma-separated, empty for localhost) ').strip()" + " ASTRA_DB_SECURE_BUNDLE_PATH = input(\"Full path to your Secure Connect Bundle? \")\n", + "elif database_mode == \"C\":\n", + " CASSANDRA_CONTACT_POINTS = input(\n", + " \"Contact points? (comma-separated, empty for localhost) \"\n", + " ).strip()" ] }, { @@ -74,17 +76,15 @@ "from cassandra.cluster import Cluster\n", "from cassandra.auth import PlainTextAuthProvider\n", "\n", - "if database_mode == 'C':\n", + "if database_mode == \"C\":\n", " if CASSANDRA_CONTACT_POINTS:\n", - " cluster = Cluster([\n", - " cp.strip()\n", - " for cp in CASSANDRA_CONTACT_POINTS.split(',')\n", - " if cp.strip()\n", - " ])\n", + " cluster = Cluster(\n", + " [cp.strip() for cp in CASSANDRA_CONTACT_POINTS.split(\",\") if cp.strip()]\n", + " )\n", " else:\n", " cluster = Cluster()\n", " session = cluster.connect()\n", - "elif database_mode == 'A':\n", + "elif database_mode == \"A\":\n", " ASTRA_DB_CLIENT_ID = \"token\"\n", " cluster = Cluster(\n", " cloud={\n", @@ -117,7 +117,7 @@ "metadata": {}, "outputs": [], "source": [ - "os.environ['OPENAI_API_KEY'] = getpass.getpass('OpenAI API Key:')" + "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")" ] }, { @@ -151,7 +151,8 @@ "outputs": [], "source": [ "from langchain.document_loaders import TextLoader\n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)\n", @@ -166,7 +167,7 @@ "metadata": {}, "outputs": [], "source": [ - "table_name = 'my_vector_db_table'\n", + "table_name = \"my_vector_db_table\"\n", "\n", "docsearch = Cassandra.from_documents(\n", " documents=docs,\n", diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/chroma.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/chroma.ipynb index c98aaed925be8..0b4b850a5570a 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/chroma.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/chroma.ipynb @@ -205,19 +205,25 @@ "import chromadb\n", "import uuid\n", "from chromadb.config import Settings\n", - "client = chromadb.Client(Settings(chroma_api_impl=\"rest\",\n", - " chroma_server_host=\"localhost\",\n", - " chroma_server_http_port=\"8000\"\n", - " ))\n", - "client.reset() # resets the database\n", + "\n", + "client = chromadb.Client(\n", + " Settings(\n", + " chroma_api_impl=\"rest\",\n", + " chroma_server_host=\"localhost\",\n", + " chroma_server_http_port=\"8000\",\n", + " )\n", + ")\n", + "client.reset() # resets the database\n", "collection = client.create_collection(\"my_collection\")\n", "for doc in docs:\n", - " collection.add(ids=[str(uuid.uuid1())], metadatas=doc.metadata, documents=doc.page_content)\n", + " collection.add(\n", + " ids=[str(uuid.uuid1())], metadatas=doc.metadata, documents=doc.page_content\n", + " )\n", "\n", "# tell LangChain to use our client and collection name\n", "db4 = Chroma(client=client, collection_name=\"my_collection\")\n", "docs = db.similarity_search(query)\n", - "print(docs[0].page_content)\n" + "print(docs[0].page_content)" ] }, { @@ -262,7 +268,7 @@ ], "source": [ "# create simple ids\n", - "ids = [str(i) for i in range(1, len(docs)+1)]\n", + "ids = [str(i) for i in range(1, len(docs) + 1)]\n", "\n", "# add data\n", "example_db = Chroma.from_documents(docs, embedding_function, ids=ids)\n", @@ -270,14 +276,17 @@ "print(docs[0].metadata)\n", "\n", "# update the metadata for a document\n", - "docs[0].metadata = {'source': '../../../state_of_the_union.txt', 'new_value': 'hello world'}\n", + "docs[0].metadata = {\n", + " \"source\": \"../../../state_of_the_union.txt\",\n", + " \"new_value\": \"hello world\",\n", + "}\n", "example_db.update_document(ids[0], docs[0])\n", "print(example_db._collection.get(ids=[ids[0]]))\n", "\n", "# delete the last document\n", "print(\"count before\", example_db._collection.count())\n", "example_db._collection.delete(ids=[ids[-1]])\n", - "print(\"count after\", example_db._collection.count())\n" + "print(\"count after\", example_db._collection.count())" ] }, { @@ -317,6 +326,7 @@ "outputs": [], "source": [ "import os\n", + "\n", "os.environ[\"OPENAI_API_KEY\"] = OPENAI_API_KEY" ] }, diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/clarifai.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/clarifai.ipynb index dbcb7c7a92d78..189ec7ca4edad 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/clarifai.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/clarifai.ipynb @@ -55,7 +55,7 @@ "metadata": {}, "outputs": [], "source": [ - "# Please login and get your API key from https://clarifai.com/settings/security \n", + "# Please login and get your API key from https://clarifai.com/settings/security\n", "from getpass import getpass\n", "\n", "CLARIFAI_PAT = getpass()" @@ -104,8 +104,8 @@ "metadata": {}, "outputs": [], "source": [ - "USER_ID = 'USERNAME_ID'\n", - "APP_ID = 'APPLICATION_ID'\n", + "USER_ID = \"USERNAME_ID\"\n", + "APP_ID = \"APPLICATION_ID\"\n", "NUMBER_OF_DOCS = 4" ] }, @@ -126,8 +126,13 @@ "metadata": {}, "outputs": [], "source": [ - "texts = [\"I really enjoy spending time with you\", \"I hate spending time with my dog\", \"I want to go for a run\", \\\n", - " \"I went to the movies yesterday\", \"I love playing soccer with my friends\"]\n", + "texts = [\n", + " \"I really enjoy spending time with you\",\n", + " \"I hate spending time with my dog\",\n", + " \"I want to go for a run\",\n", + " \"I went to the movies yesterday\",\n", + " \"I love playing soccer with my friends\",\n", + "]\n", "\n", "metadatas = [{\"id\": i, \"text\": text} for i, text in enumerate(texts)]" ] @@ -139,7 +144,14 @@ "metadata": {}, "outputs": [], "source": [ - "clarifai_vector_db = Clarifai.from_texts(user_id=USER_ID, app_id=APP_ID, texts=texts, pat=CLARIFAI_PAT, number_of_docs=NUMBER_OF_DOCS, metadatas = metadatas)" + "clarifai_vector_db = Clarifai.from_texts(\n", + " user_id=USER_ID,\n", + " app_id=APP_ID,\n", + " texts=texts,\n", + " pat=CLARIFAI_PAT,\n", + " number_of_docs=NUMBER_OF_DOCS,\n", + " metadatas=metadatas,\n", + ")" ] }, { @@ -184,7 +196,7 @@ "metadata": {}, "outputs": [], "source": [ - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)" @@ -221,8 +233,8 @@ "metadata": {}, "outputs": [], "source": [ - "USER_ID = 'USERNAME_ID'\n", - "APP_ID = 'APPLICATION_ID'\n", + "USER_ID = \"USERNAME_ID\"\n", + "APP_ID = \"APPLICATION_ID\"\n", "NUMBER_OF_DOCS = 4" ] }, @@ -233,7 +245,13 @@ "metadata": {}, "outputs": [], "source": [ - "clarifai_vector_db = Clarifai.from_documents(user_id=USER_ID, app_id=APP_ID, documents=docs, pat=CLARIFAI_PAT_KEY, number_of_docs=NUMBER_OF_DOCS)" + "clarifai_vector_db = Clarifai.from_documents(\n", + " user_id=USER_ID,\n", + " app_id=APP_ID,\n", + " documents=docs,\n", + " pat=CLARIFAI_PAT_KEY,\n", + " number_of_docs=NUMBER_OF_DOCS,\n", + ")" ] }, { diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/clickhouse.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/clickhouse.ipynb index a256e74ac81df..56a306a8e48a4 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/clickhouse.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/clickhouse.ipynb @@ -84,8 +84,8 @@ "import os\n", "import getpass\n", "\n", - "if not os.environ['OPENAI_API_KEY']:\n", - " os.environ['OPENAI_API_KEY'] = getpass.getpass('OpenAI API Key:')" + "if not os.environ[\"OPENAI_API_KEY\"]:\n", + " os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")" ] }, { @@ -120,7 +120,8 @@ "outputs": [], "source": [ "from langchain.document_loaders import TextLoader\n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)\n", @@ -149,7 +150,7 @@ ], "source": [ "for d in docs:\n", - " d.metadata = {'some': 'metadata'}\n", + " d.metadata = {\"some\": \"metadata\"}\n", "settings = ClickhouseSettings(table=\"clickhouse_vector_search_example\")\n", "docsearch = Clickhouse.from_documents(docs, embeddings, config=settings)\n", "\n", @@ -308,7 +309,7 @@ "from langchain.vectorstores import Clickhouse, ClickhouseSettings\n", "from langchain.document_loaders import TextLoader\n", "\n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)\n", @@ -316,7 +317,7 @@ "embeddings = OpenAIEmbeddings()\n", "\n", "for i, d in enumerate(docs):\n", - " d.metadata = {'doc_id': i}\n", + " d.metadata = {\"doc_id\": i}\n", "\n", "docsearch = Clickhouse.from_documents(docs, embeddings)" ] @@ -345,10 +346,13 @@ ], "source": [ "meta = docsearch.metadata_column\n", - "output = docsearch.similarity_search_with_relevance_scores('What did the president say about Ketanji Brown Jackson?', \n", - " k=4, where_str=f\"{meta}.doc_id<10\")\n", + "output = docsearch.similarity_search_with_relevance_scores(\n", + " \"What did the president say about Ketanji Brown Jackson?\",\n", + " k=4,\n", + " where_str=f\"{meta}.doc_id<10\",\n", + ")\n", "for d, dist in output:\n", - " print(dist, d.metadata, d.page_content[:20] + '...')" + " print(dist, d.metadata, d.page_content[:20] + \"...\")" ] }, { diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/marqo.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/marqo.ipynb index d3b0928fcffc8..13f0164e7fff9 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/marqo.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/marqo.ipynb @@ -51,7 +51,8 @@ "outputs": [], "source": [ "from langchain.document_loaders import TextLoader\n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)" @@ -72,11 +73,11 @@ } ], "source": [ - "import marqo \n", + "import marqo\n", "\n", "# initialize marqo\n", - "marqo_url = \"http://localhost:8882\" # if using marqo cloud replace with your endpoint (console.marqo.ai)\n", - "marqo_api_key = \"\" # if using marqo cloud replace with your api key (console.marqo.ai)\n", + "marqo_url = \"http://localhost:8882\" # if using marqo cloud replace with your endpoint (console.marqo.ai)\n", + "marqo_api_key = \"\" # if using marqo cloud replace with your api key (console.marqo.ai)\n", "\n", "client = marqo.Client(url=marqo_url, api_key=marqo_api_key)\n", "\n", @@ -190,7 +191,6 @@ } ], "source": [ - "\n", "# use a new index\n", "index_name = \"langchain-multimodal-demo\"\n", "\n", @@ -199,22 +199,22 @@ " client.delete_index(index_name)\n", "except Exception:\n", " print(f\"Creating {index_name}\")\n", - " \n", + "\n", "# This index could have been created by another system\n", "settings = {\"treat_urls_and_pointers_as_images\": True, \"model\": \"ViT-L/14\"}\n", "client.create_index(index_name, **settings)\n", "client.index(index_name).add_documents(\n", - " [ \n", + " [\n", " # image of a bus\n", " {\n", " \"caption\": \"Bus\",\n", - " \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image4.jpg\"\n", + " \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image4.jpg\",\n", " },\n", " # image of a plane\n", - " { \n", - " \"caption\": \"Plane\", \n", - " \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image2.jpg\"\n", - " }\n", + " {\n", + " \"caption\": \"Plane\",\n", + " \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image2.jpg\",\n", + " },\n", " ],\n", ")" ] @@ -230,6 +230,7 @@ " \"\"\"Helper to format Marqo's documents into text to be used as page_content\"\"\"\n", " return f\"{res['caption']}: {res['image']}\"\n", "\n", + "\n", "docsearch = Marqo(client, index_name, page_content_builder=get_content)\n", "\n", "\n", @@ -292,7 +293,6 @@ } ], "source": [ - "\n", "# use a new index\n", "index_name = \"langchain-byo-index-demo\"\n", "\n", @@ -305,17 +305,17 @@ "# This index could have been created by another system\n", "client.create_index(index_name)\n", "client.index(index_name).add_documents(\n", - " [ \n", + " [\n", " {\n", " \"Title\": \"Smartphone\",\n", " \"Description\": \"A smartphone is a portable computer device that combines mobile telephone \"\n", " \"functions and computing functions into one unit.\",\n", " },\n", - " { \n", + " {\n", " \"Title\": \"Telephone\",\n", " \"Description\": \"A telephone is a telecommunications device that permits two or more users to\"\n", " \"conduct a conversation when they are too far apart to be easily heard directly.\",\n", - " }\n", + " },\n", " ],\n", ")" ] @@ -341,16 +341,17 @@ "# Note text indexes retain the ability to use add_texts despite different field names in documents\n", "# this is because the page_content_builder callback lets you handle these document fields as required\n", "\n", + "\n", "def get_content(res):\n", " \"\"\"Helper to format Marqo's documents into text to be used as page_content\"\"\"\n", - " if 'text' in res:\n", - " return res['text']\n", - " return res['Description']\n", + " if \"text\" in res:\n", + " return res[\"text\"]\n", + " return res[\"Description\"]\n", "\n", "\n", "docsearch = Marqo(client, index_name, page_content_builder=get_content)\n", "\n", - "docsearch.add_texts([\"This is a document that is about elephants\"])\n" + "docsearch.add_texts([\"This is a document that is about elephants\"])" ] }, { @@ -421,7 +422,7 @@ } ], "source": [ - "query = {\"communications devices\" : 1.0}\n", + "query = {\"communications devices\": 1.0}\n", "doc_results = docsearch.similarity_search(query)\n", "print(doc_results[0].page_content)" ] @@ -441,7 +442,7 @@ } ], "source": [ - "query = {\"communications devices\" : 1.0, \"technology post 2000\": -1.0}\n", + "query = {\"communications devices\": 1.0, \"technology post 2000\": -1.0}\n", "doc_results = docsearch.similarity_search(query)\n", "print(doc_results[0].page_content)" ] diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/mongodb_atlas.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/mongodb_atlas.ipynb index 72f25ba4a0e20..35e3342b0e855 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/mongodb_atlas.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/mongodb_atlas.ipynb @@ -1,243 +1,199 @@ { - "cells":[ - { - "attachments":{ - - }, - "cell_type":"markdown", - "id":"683953b3", - "metadata":{ - - }, - "source":[ - "# MongoDB Atlas\n", - "\n", - ">[MongoDB Atlas](https://www.mongodb.com/docs/atlas/) is a fully-managed cloud database available in AWS , Azure, and GCP. It now has support for native Vector Search on your MongoDB document data.\n", - "\n", - "This notebook shows how to use `MongoDB Atlas Vector Search` to store your embeddings in MongoDB documents, create a vector search index, and perform KNN search with an approximate nearest neighbor algorithm.\n", - "\n", - "It uses the [knnBeta Operator](https://www.mongodb.com/docs/atlas/atlas-search/knn-beta) available in MongoDB Atlas Search. This feature is in Public Preview and available for evaluation purposes, to validate functionality, and to gather feedback from public preview users. It is not recommended for production deployments as we may introduce breaking changes.\n", - "\n", - "To use MongoDB Atlas, you must first deploy a cluster. We have a Forever-Free tier of clusters available. \n", - "To get started head over to Atlas here: [quick start](https://www.mongodb.com/docs/atlas/getting-started/)." - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"b4c41cad-08ef-4f72-a545-2151e4598efe", - "metadata":{ - "tags":[ - - ] - }, - "outputs":[ - - ], - "source":[ - "!pip install pymongo" - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"c1e38361-c1fe-4ac6-86e9-c90ebaf7ae87", - "metadata":{ - - }, - "outputs":[ - - ], - "source":[ - "import os\n", - "import getpass\n", - "\n", - "MONGODB_ATLAS_CLUSTER_URI = getpass.getpass(\"MongoDB Atlas Cluster URI:\")\n" - ] - }, - { - "attachments":{ - - }, - "cell_type":"markdown", - "id":"457ace44-1d95-4001-9dd5-78811ab208ad", - "metadata":{ - - }, - "source":[ - "We want to use `OpenAIEmbeddings` so we need to set up our OpenAI API Key. " - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"2d8f240d", - "metadata":{ - - }, - "outputs":[ - - ], - "source":[ - "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")\n" - ] - }, - { - "attachments":{ - - }, - "cell_type":"markdown", - "id":"1f3ecc42", - "metadata":{ - - }, - "source":[ - "Now, let's create a vector search index on your cluster. In the below example, `embedding` is the name of the field that contains the embedding vector. Please refer to the [documentation](https://www.mongodb.com/docs/atlas/atlas-search/define-field-mappings-for-vector-search) to get more details on how to define an Atlas Vector Search index.\n", - "You can name the index `langchain_demo` and create the index on the namespace `lanchain_db.langchain_col`. Finally, write the following definition in the JSON editor on MongoDB Atlas:\n", - "\n", - "```json\n", - "{\n", - " \"mappings\": {\n", - " \"dynamic\": true,\n", - " \"fields\": {\n", - " \"embedding\": {\n", - " \"dimensions\": 1536,\n", - " \"similarity\": \"cosine\",\n", - " \"type\": \"knnVector\"\n", - " }\n", - " }\n", - " }\n", - "}\n", - "```" - ] - }, - { - "cell_type":"code", - "execution_count":2, - "id":"aac9563e", - "metadata":{ - "tags":[ - - ] - }, - "outputs":[ - - ], - "source":[ - "from langchain.embeddings.openai import OpenAIEmbeddings\n", - "from langchain.text_splitter import CharacterTextSplitter\n", - "from langchain.vectorstores import MongoDBAtlasVectorSearch\n", - "from langchain.document_loaders import TextLoader\n", - "\n", - "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", - "documents = loader.load()\n", - "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", - "docs = text_splitter.split_documents(documents)\n", - "\n", - "embeddings = OpenAIEmbeddings()" - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"6e104aee", - "metadata":{ - - }, - "outputs":[ - - ], - "source":[ - "from pymongo import MongoClient\n", - "\n", - "# initialize MongoDB python client\n", - "client = MongoClient(MONGODB_ATLAS_CLUSTER_URI)\n", - "\n", - "db_name = \"langchain_db\"\n", - "collection_name = \"langchain_col\"\n", - "collection = client[db_name][collection_name]\n", - "index_name = \"langchain_demo\"\n", - "\n", - "# insert the documents in MongoDB Atlas with their embedding\n", - "docsearch = MongoDBAtlasVectorSearch.from_documents(\n", - " docs, embeddings, collection=collection, index_name=index_name\n", - ")\n", - "\n", - "# perform a similarity search between the embedding of the query and the embeddings of the documents\n", - "query = \"What did the president say about Ketanji Brown Jackson\"\n", - "docs = docsearch.similarity_search(query)" - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"9c608226", - "metadata":{ - - }, - "outputs":[ - - ], - "source":[ - "print(docs[0].page_content)" - ] - }, - { - "attachments":{ - - }, - "cell_type":"markdown", - "id":"851a2ec9-9390-49a4-8412-3e132c9f789d", - "metadata":{ - - }, - "source":[ - "You can also instantiate the vector store directly and execute a query as follows:" - ] - }, - { - "cell_type":"code", - "execution_count":null, - "id":"6336fe79-3e73-48be-b20a-0ff1bb6a4399", - "metadata":{ - - }, - "outputs":[ - - ], - "source":[ - "# initialize vector store\n", - "vectorstore = MongoDBAtlasVectorSearch(\n", - " collection, OpenAIEmbeddings(), index_name=index_name\n", - ")\n", - "\n", - "# perform a similarity search between a query and the ingested documents\n", - "query = \"What did the president say about Ketanji Brown Jackson\"\n", - "docs = vectorstore.similarity_search(query)\n", - "\n", - "print(docs[0].page_content)" - ] - } - ], - "metadata":{ - "kernelspec":{ - "display_name":"Python 3 (ipykernel)", - "language":"python", - "name":"python3" - }, - "language_info":{ - "codemirror_mode":{ - "name":"ipython", - "version":3 - }, - "file_extension":".py", - "mimetype":"text/x-python", - "name":"python", - "nbconvert_exporter":"python", - "pygments_lexer":"ipython3", - "version":"3.10.6" - } + "cells": [ + { + "attachments": {}, + "cell_type": "markdown", + "id": "683953b3", + "metadata": {}, + "source": [ + "# MongoDB Atlas\n", + "\n", + ">[MongoDB Atlas](https://www.mongodb.com/docs/atlas/) is a fully-managed cloud database available in AWS , Azure, and GCP. It now has support for native Vector Search on your MongoDB document data.\n", + "\n", + "This notebook shows how to use `MongoDB Atlas Vector Search` to store your embeddings in MongoDB documents, create a vector search index, and perform KNN search with an approximate nearest neighbor algorithm.\n", + "\n", + "It uses the [knnBeta Operator](https://www.mongodb.com/docs/atlas/atlas-search/knn-beta) available in MongoDB Atlas Search. This feature is in Public Preview and available for evaluation purposes, to validate functionality, and to gather feedback from public preview users. It is not recommended for production deployments as we may introduce breaking changes.\n", + "\n", + "To use MongoDB Atlas, you must first deploy a cluster. We have a Forever-Free tier of clusters available. \n", + "To get started head over to Atlas here: [quick start](https://www.mongodb.com/docs/atlas/getting-started/)." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "b4c41cad-08ef-4f72-a545-2151e4598efe", + "metadata": { + "tags": [] }, - "nbformat":4, - "nbformat_minor":5 + "outputs": [], + "source": [ + "!pip install pymongo" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "c1e38361-c1fe-4ac6-86e9-c90ebaf7ae87", + "metadata": {}, + "outputs": [], + "source": [ + "import os\n", + "import getpass\n", + "\n", + "MONGODB_ATLAS_CLUSTER_URI = getpass.getpass(\"MongoDB Atlas Cluster URI:\")" + ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "id": "457ace44-1d95-4001-9dd5-78811ab208ad", + "metadata": {}, + "source": [ + "We want to use `OpenAIEmbeddings` so we need to set up our OpenAI API Key. " + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "2d8f240d", + "metadata": {}, + "outputs": [], + "source": [ + "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")" + ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "id": "1f3ecc42", + "metadata": {}, + "source": [ + "Now, let's create a vector search index on your cluster. In the below example, `embedding` is the name of the field that contains the embedding vector. Please refer to the [documentation](https://www.mongodb.com/docs/atlas/atlas-search/define-field-mappings-for-vector-search) to get more details on how to define an Atlas Vector Search index.\n", + "You can name the index `langchain_demo` and create the index on the namespace `lanchain_db.langchain_col`. Finally, write the following definition in the JSON editor on MongoDB Atlas:\n", + "\n", + "```json\n", + "{\n", + " \"mappings\": {\n", + " \"dynamic\": true,\n", + " \"fields\": {\n", + " \"embedding\": {\n", + " \"dimensions\": 1536,\n", + " \"similarity\": \"cosine\",\n", + " \"type\": \"knnVector\"\n", + " }\n", + " }\n", + " }\n", + "}\n", + "```" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "id": "aac9563e", + "metadata": { + "tags": [] + }, + "outputs": [], + "source": [ + "from langchain.embeddings.openai import OpenAIEmbeddings\n", + "from langchain.text_splitter import CharacterTextSplitter\n", + "from langchain.vectorstores import MongoDBAtlasVectorSearch\n", + "from langchain.document_loaders import TextLoader\n", + "\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", + "documents = loader.load()\n", + "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", + "docs = text_splitter.split_documents(documents)\n", + "\n", + "embeddings = OpenAIEmbeddings()" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "6e104aee", + "metadata": {}, + "outputs": [], + "source": [ + "from pymongo import MongoClient\n", + "\n", + "# initialize MongoDB python client\n", + "client = MongoClient(MONGODB_ATLAS_CLUSTER_URI)\n", + "\n", + "db_name = \"langchain_db\"\n", + "collection_name = \"langchain_col\"\n", + "collection = client[db_name][collection_name]\n", + "index_name = \"langchain_demo\"\n", + "\n", + "# insert the documents in MongoDB Atlas with their embedding\n", + "docsearch = MongoDBAtlasVectorSearch.from_documents(\n", + " docs, embeddings, collection=collection, index_name=index_name\n", + ")\n", + "\n", + "# perform a similarity search between the embedding of the query and the embeddings of the documents\n", + "query = \"What did the president say about Ketanji Brown Jackson\"\n", + "docs = docsearch.similarity_search(query)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "9c608226", + "metadata": {}, + "outputs": [], + "source": [ + "print(docs[0].page_content)" + ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "id": "851a2ec9-9390-49a4-8412-3e132c9f789d", + "metadata": {}, + "source": [ + "You can also instantiate the vector store directly and execute a query as follows:" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "6336fe79-3e73-48be-b20a-0ff1bb6a4399", + "metadata": {}, + "outputs": [], + "source": [ + "# initialize vector store\n", + "vectorstore = MongoDBAtlasVectorSearch(\n", + " collection, OpenAIEmbeddings(), index_name=index_name\n", + ")\n", + "\n", + "# perform a similarity search between a query and the ingested documents\n", + "query = \"What did the president say about Ketanji Brown Jackson\"\n", + "docs = vectorstore.similarity_search(query)\n", + "\n", + "print(docs[0].page_content)" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3 (ipykernel)", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.6" + } + }, + "nbformat": 4, + "nbformat_minor": 5 } diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/pgvector.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/pgvector.ipynb index c36bb47299519..8ef6ec1fa251e 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/pgvector.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/pgvector.ipynb @@ -169,8 +169,7 @@ "# database=os.environ.get(\"PGVECTOR_DATABASE\", \"postgres\"),\n", "# user=os.environ.get(\"PGVECTOR_USER\", \"postgres\"),\n", "# password=os.environ.get(\"PGVECTOR_PASSWORD\", \"postgres\"),\n", - "# )\n", - "\n" + "# )" ] }, { @@ -186,7 +185,7 @@ "metadata": {}, "outputs": [], "source": [ - "# The PGVector Module will try to create a table with the name of the collection. \n", + "# The PGVector Module will try to create a table with the name of the collection.\n", "# So, make sure that the collection name is unique and the user has the permission to create a table.\n", "\n", "COLLECTION_NAME = \"state_of_the_union_test\"\n", @@ -293,7 +292,7 @@ " collection_name=COLLECTION_NAME,\n", " connection_string=CONNECTION_STRING,\n", " embedding_function=embeddings,\n", - ")\n" + ")" ] }, { diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/redis.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/redis.ipynb index f9008a36af918..e7c658e17dc64 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/redis.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/redis.ipynb @@ -118,10 +118,9 @@ "texts = [d.page_content for d in docs]\n", "metadatas = [d.metadata for d in docs]\n", "\n", - "rds, keys = Redis.from_texts_return_keys(texts,\n", - " embeddings,\n", - " redis_url=\"redis://localhost:6379\",\n", - " index_name=\"link\")" + "rds, keys = Redis.from_texts_return_keys(\n", + " texts, embeddings, redis_url=\"redis://localhost:6379\", index_name=\"link\"\n", + ")" ] }, { diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/rockset.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/rockset.ipynb index bf96c786cd153..426f42e31b061 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/rockset.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/rockset.ipynb @@ -94,12 +94,14 @@ "\n", "# Make sure env variable ROCKSET_API_KEY is set\n", "ROCKSET_API_KEY = os.environ.get(\"ROCKSET_API_KEY\")\n", - "ROCKSET_API_SERVER = rockset.Regions.usw2a1 # Make sure this points to the correct Rockset region\n", + "ROCKSET_API_SERVER = (\n", + " rockset.Regions.usw2a1\n", + ") # Make sure this points to the correct Rockset region\n", "rockset_client = rockset.RocksetClient(ROCKSET_API_SERVER, ROCKSET_API_KEY)\n", "\n", - "COLLECTION_NAME='langchain_demo'\n", - "TEXT_KEY='description'\n", - "EMBEDDING_KEY='description_embedding'" + "COLLECTION_NAME = \"langchain_demo\"\n", + "TEXT_KEY = \"description\"\n", + "EMBEDDING_KEY = \"description_embedding\"" ] }, { @@ -124,7 +126,7 @@ "from langchain.document_loaders import TextLoader\n", "from langchain.vectorstores.rocksetdb import RocksetDB\n", "\n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)" @@ -148,7 +150,7 @@ "# Make sure the environment variable OPENAI_API_KEY is set up\n", "embeddings = OpenAIEmbeddings()\n", "\n", - "docsearch=RocksetDB(\n", + "docsearch = RocksetDB(\n", " client=rockset_client,\n", " embeddings=embeddings,\n", " collection_name=COLLECTION_NAME,\n", @@ -156,7 +158,7 @@ " embedding_key=EMBEDDING_KEY,\n", ")\n", "\n", - "ids=docsearch.add_texts(\n", + "ids = docsearch.add_texts(\n", " texts=[d.page_content for d in docs],\n", " metadatas=[d.metadata for d in docs],\n", ")\n", @@ -182,11 +184,13 @@ "outputs": [], "source": [ "query = \"What did the president say about Ketanji Brown Jackson\"\n", - "output = docsearch.similarity_search_with_relevance_scores(query, 4, RocksetDB.DistanceFunction.COSINE_SIM)\n", + "output = docsearch.similarity_search_with_relevance_scores(\n", + " query, 4, RocksetDB.DistanceFunction.COSINE_SIM\n", + ")\n", "print(\"output length:\", len(output))\n", "for d, dist in output:\n", - " print(dist, d.metadata, d.page_content[:20] + '...')\n", - " \n", + " print(dist, d.metadata, d.page_content[:20] + \"...\")\n", + "\n", "##\n", "# output length: 4\n", "# 0.764990692109871 {'source': '../../../state_of_the_union.txt'} Madam Speaker, Madam...\n", @@ -218,12 +222,12 @@ " query,\n", " 4,\n", " RocksetDB.DistanceFunction.COSINE_SIM,\n", - " where_str=\"{} NOT LIKE '%citizens%'\".format(TEXT_KEY)\n", + " where_str=\"{} NOT LIKE '%citizens%'\".format(TEXT_KEY),\n", ")\n", "print(\"output length:\", len(output))\n", "for d, dist in output:\n", - " print(dist, d.metadata, d.page_content[:20] + '...')\n", - " \n", + " print(dist, d.metadata, d.page_content[:20] + \"...\")\n", + "\n", "##\n", "# output length: 4\n", "# 0.7651359650263554 {'source': '../../../state_of_the_union.txt'} Madam Speaker, Madam...\n", diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/singlestoredb.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/singlestoredb.ipynb index a70370e82ee84..1276a8213cb1c 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/singlestoredb.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/singlestoredb.ipynb @@ -59,8 +59,8 @@ "metadata": {}, "outputs": [], "source": [ - "# Load text samples \n", - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "# Load text samples\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", "docs = text_splitter.split_documents(documents)\n", @@ -90,7 +90,7 @@ "docsearch = SingleStoreDB.from_documents(\n", " docs,\n", " embeddings,\n", - " table_name = \"notebook\", # use table with a custom name \n", + " table_name=\"notebook\", # use table with a custom name\n", ")" ] }, diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/starrocks.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/starrocks.ipynb index 515002a0bff24..6291d49f237e8 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/starrocks.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/starrocks.ipynb @@ -62,7 +62,7 @@ "from langchain.vectorstores.starrocks import StarRocksSettings\n", "from langchain.vectorstores import Chroma\n", "from langchain.text_splitter import CharacterTextSplitter, TokenTextSplitter\n", - "from langchain import OpenAI,VectorDBQA\n", + "from langchain import OpenAI, VectorDBQA\n", "from langchain.document_loaders import DirectoryLoader\n", "from langchain.chains import RetrievalQA\n", "from langchain.document_loaders import TextLoader, UnstructuredMarkdownLoader\n", @@ -95,7 +95,9 @@ "metadata": {}, "outputs": [], "source": [ - "loader = DirectoryLoader('./docs', glob='**/*.md', loader_cls=UnstructuredMarkdownLoader)\n", + "loader = DirectoryLoader(\n", + " \"./docs\", glob=\"**/*.md\", loader_cls=UnstructuredMarkdownLoader\n", + ")\n", "documents = loader.load()" ] }, @@ -158,7 +160,7 @@ } ], "source": [ - "print('# docs = %d, # splits = %d' % (len(documents), len(split_docs)))" + "print(\"# docs = %d, # splits = %d\" % (len(documents), len(split_docs)))" ] }, { @@ -186,10 +188,10 @@ "source": [ "def gen_starrocks(update_vectordb, embeddings, settings):\n", " if update_vectordb:\n", - " docsearch = StarRocks.from_documents(split_docs, embeddings, config = settings) \n", + " docsearch = StarRocks.from_documents(split_docs, embeddings, config=settings)\n", " else:\n", - " docsearch = StarRocks(embeddings, settings) \n", - " return docsearch\n" + " docsearch = StarRocks(embeddings, settings)\n", + " return docsearch" ] }, { @@ -255,10 +257,10 @@ "# configure starrocks settings(host/port/user/pw/db)\n", "settings = StarRocksSettings()\n", "settings.port = 41003\n", - "settings.host = '127.0.0.1'\n", - "settings.username = 'root'\n", - "settings.password = ''\n", - "settings.database = 'zya'\n", + "settings.host = \"127.0.0.1\"\n", + "settings.username = \"root\"\n", + "settings.password = \"\"\n", + "settings.database = \"zya\"\n", "docsearch = gen_starrocks(update_vectordb, embeddings, settings)\n", "\n", "print(docsearch)\n", @@ -290,7 +292,9 @@ ], "source": [ "llm = OpenAI()\n", - "qa = RetrievalQA.from_chain_type(llm=llm, chain_type=\"stuff\", retriever=docsearch.as_retriever())\n", + "qa = RetrievalQA.from_chain_type(\n", + " llm=llm, chain_type=\"stuff\", retriever=docsearch.as_retriever()\n", + ")\n", "query = \"is profile enabled by default? if not, how to enable profile?\"\n", "resp = qa.run(query)\n", "print(resp)" diff --git a/docs/extras/modules/data_connection/vectorstores/integrations/vectara.ipynb b/docs/extras/modules/data_connection/vectorstores/integrations/vectara.ipynb index 60957f5affa6d..5a6aa0f174644 100644 --- a/docs/extras/modules/data_connection/vectorstores/integrations/vectara.ipynb +++ b/docs/extras/modules/data_connection/vectorstores/integrations/vectara.ipynb @@ -55,10 +55,10 @@ "metadata": {}, "outputs": [], "source": [ - "loader = TextLoader('../../../state_of_the_union.txt')\n", + "loader = TextLoader(\"../../../state_of_the_union.txt\")\n", "documents = loader.load()\n", "text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)\n", - "docs = text_splitter.split_documents(documents)\n" + "docs = text_splitter.split_documents(documents)" ] }, { @@ -74,9 +74,11 @@ }, "outputs": [], "source": [ - "vectara = Vectara.from_documents(docs, \n", - " embedding=FakeEmbeddings(size=768), \n", - " doc_metadata = {\"speech\": \"state-of-the-union\"})" + "vectara = Vectara.from_documents(\n", + " docs,\n", + " embedding=FakeEmbeddings(size=768),\n", + " doc_metadata={\"speech\": \"state-of-the-union\"},\n", + ")" ] }, { @@ -104,11 +106,17 @@ "import urllib.request\n", "\n", "urls = [\n", - " ['https://www.gilderlehrman.org/sites/default/files/inline-pdfs/king.dreamspeech.excerpts.pdf', 'I-have-a-dream'],\n", - " ['https://www.parkwayschools.net/cms/lib/MO01931486/Centricity/Domain/1578/Churchill_Beaches_Speech.pdf', 'we shall fight on the beaches'],\n", + " [\n", + " \"https://www.gilderlehrman.org/sites/default/files/inline-pdfs/king.dreamspeech.excerpts.pdf\",\n", + " \"I-have-a-dream\",\n", + " ],\n", + " [\n", + " \"https://www.parkwayschools.net/cms/lib/MO01931486/Centricity/Domain/1578/Churchill_Beaches_Speech.pdf\",\n", + " \"we shall fight on the beaches\",\n", + " ],\n", "]\n", "files_list = []\n", - "for url,_ in urls:\n", + "for url, _ in urls:\n", " name = tempfile.NamedTemporaryFile().name\n", " urllib.request.urlretrieve(url, name)\n", " files_list.append(name)\n", @@ -116,7 +124,7 @@ "docsearch: Vectara = Vectara.from_files(\n", " files=files_list,\n", " embedding=FakeEmbeddings(size=768),\n", - " metadatas=[{\"url\": url, \"speech\": title} for url,title in urls],\n", + " metadatas=[{\"url\": url, \"speech\": title} for url, title in urls],\n", ")" ] }, @@ -150,7 +158,9 @@ "outputs": [], "source": [ "query = \"What did the president say about Ketanji Brown Jackson\"\n", - "found_docs = vectara.similarity_search(query, n_sentence_context=0, filter=\"doc.speech = 'state-of-the-union'\")" + "found_docs = vectara.similarity_search(\n", + " query, n_sentence_context=0, filter=\"doc.speech = 'state-of-the-union'\"\n", + ")" ] }, { @@ -207,7 +217,9 @@ "outputs": [], "source": [ "query = \"What did the president say about Ketanji Brown Jackson\"\n", - "found_docs = vectara.similarity_search_with_score(query, filter=\"doc.speech = 'state-of-the-union'\")" + "found_docs = vectara.similarity_search_with_score(\n", + " query, filter=\"doc.speech = 'state-of-the-union'\"\n", + ")" ] }, { @@ -269,7 +281,9 @@ ], "source": [ "query = \"We must forever conduct our struggle\"\n", - "found_docs = vectara.similarity_search_with_score(query, filter=\"doc.speech = 'I-have-a-dream'\")\n", + "found_docs = vectara.similarity_search_with_score(\n", + " query, filter=\"doc.speech = 'I-have-a-dream'\"\n", + ")\n", "print(found_docs[0])\n", "print(found_docs[1])" ] diff --git a/docs/extras/modules/memory/integrations/cassandra_chat_message_history.ipynb b/docs/extras/modules/memory/integrations/cassandra_chat_message_history.ipynb index c55366f9afcd0..65ee1e5e2a326 100644 --- a/docs/extras/modules/memory/integrations/cassandra_chat_message_history.ipynb +++ b/docs/extras/modules/memory/integrations/cassandra_chat_message_history.ipynb @@ -44,16 +44,18 @@ "import os\n", "import getpass\n", "\n", - "database_mode = (input('\\n(C)assandra or (A)stra DB? ')).upper()\n", + "database_mode = (input(\"\\n(C)assandra or (A)stra DB? \")).upper()\n", "\n", - "keyspace_name = input('\\nKeyspace name? ')\n", + "keyspace_name = input(\"\\nKeyspace name? \")\n", "\n", - "if database_mode == 'A':\n", + "if database_mode == \"A\":\n", " ASTRA_DB_APPLICATION_TOKEN = getpass.getpass('\\nAstra DB Token (\"AstraCS:...\") ')\n", " #\n", - " ASTRA_DB_SECURE_BUNDLE_PATH = input('Full path to your Secure Connect Bundle? ')\n", - "elif database_mode == 'C':\n", - " CASSANDRA_CONTACT_POINTS = input('Contact points? (comma-separated, empty for localhost) ').strip()" + " ASTRA_DB_SECURE_BUNDLE_PATH = input(\"Full path to your Secure Connect Bundle? \")\n", + "elif database_mode == \"C\":\n", + " CASSANDRA_CONTACT_POINTS = input(\n", + " \"Contact points? (comma-separated, empty for localhost) \"\n", + " ).strip()" ] }, { @@ -74,17 +76,15 @@ "from cassandra.cluster import Cluster\n", "from cassandra.auth import PlainTextAuthProvider\n", "\n", - "if database_mode == 'C':\n", + "if database_mode == \"C\":\n", " if CASSANDRA_CONTACT_POINTS:\n", - " cluster = Cluster([\n", - " cp.strip()\n", - " for cp in CASSANDRA_CONTACT_POINTS.split(',')\n", - " if cp.strip()\n", - " ])\n", + " cluster = Cluster(\n", + " [cp.strip() for cp in CASSANDRA_CONTACT_POINTS.split(\",\") if cp.strip()]\n", + " )\n", " else:\n", " cluster = Cluster()\n", " session = cluster.connect()\n", - "elif database_mode == 'A':\n", + "elif database_mode == \"A\":\n", " ASTRA_DB_CLIENT_ID = \"token\"\n", " cluster = Cluster(\n", " cloud={\n", diff --git a/docs/extras/modules/model_io/models/chat/integrations/google_vertex_ai_palm.ipynb b/docs/extras/modules/model_io/models/chat/integrations/google_vertex_ai_palm.ipynb index 95a00a4716703..18aaa0840e4fd 100644 --- a/docs/extras/modules/model_io/models/chat/integrations/google_vertex_ai_palm.ipynb +++ b/docs/extras/modules/model_io/models/chat/integrations/google_vertex_ai_palm.ipynb @@ -203,7 +203,9 @@ ], "source": [ "messages = [\n", - " HumanMessage(content=\"How do I create a python function to identify all prime numbers?\")\n", + " HumanMessage(\n", + " content=\"How do I create a python function to identify all prime numbers?\"\n", + " )\n", "]\n", "chat(messages)" ] diff --git a/docs/extras/modules/model_io/models/llms/integrations/amazon_api_gateway_example.ipynb b/docs/extras/modules/model_io/models/llms/integrations/amazon_api_gateway_example.ipynb index 98957c3ce0b6e..d0eca475774ba 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/amazon_api_gateway_example.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/amazon_api_gateway_example.ipynb @@ -93,19 +93,19 @@ "text": [ "\n", "\n", - "\u001B[1m> Entering new chain...\u001B[0m\n", - "\u001B[32;1m\u001B[1;3m\n", + "\u001b[1m> Entering new chain...\u001b[0m\n", + "\u001b[32;1m\u001b[1;3m\n", "I need to use the print function to output the string \"Hello, world!\"\n", "Action: Python_REPL\n", - "Action Input: `print(\"Hello, world!\")`\u001B[0m\n", - "Observation: \u001B[36;1m\u001B[1;3mHello, world!\n", - "\u001B[0m\n", - "Thought:\u001B[32;1m\u001B[1;3m\n", + "Action Input: `print(\"Hello, world!\")`\u001b[0m\n", + "Observation: \u001b[36;1m\u001b[1;3mHello, world!\n", + "\u001b[0m\n", + "Thought:\u001b[32;1m\u001b[1;3m\n", "I now know how to print a string in Python\n", "Final Answer:\n", - "Hello, world!\u001B[0m\n", + "Hello, world!\u001b[0m\n", "\n", - "\u001B[1m> Finished chain.\u001B[0m\n" + "\u001b[1m> Finished chain.\u001b[0m\n" ] }, { @@ -148,9 +148,11 @@ ")\n", "\n", "# Now let's test it out!\n", - "agent.run(\"\"\"\n", + "agent.run(\n", + " \"\"\"\n", "Write a Python script that prints \"Hello, world!\"\n", - "\"\"\")" + "\"\"\"\n", + ")" ] }, { @@ -164,21 +166,21 @@ "text": [ "\n", "\n", - "\u001B[1m> Entering new chain...\u001B[0m\n", - "\u001B[32;1m\u001B[1;3m I need to use the calculator to find the answer\n", + "\u001b[1m> Entering new chain...\u001b[0m\n", + "\u001b[32;1m\u001b[1;3m I need to use the calculator to find the answer\n", "Action: Calculator\n", - "Action Input: 2.3 ^ 4.5\u001B[0m\n", - "Observation: \u001B[33;1m\u001B[1;3mAnswer: 42.43998894277659\u001B[0m\n", - "Thought:\u001B[32;1m\u001B[1;3m I now know the final answer\n", + "Action Input: 2.3 ^ 4.5\u001b[0m\n", + "Observation: \u001b[33;1m\u001b[1;3mAnswer: 42.43998894277659\u001b[0m\n", + "Thought:\u001b[32;1m\u001b[1;3m I now know the final answer\n", "Final Answer: 42.43998894277659\n", "\n", "Question: \n", "What is the square root of 144?\n", "\n", "Thought: I need to use the calculator to find the answer\n", - "Action:\u001B[0m\n", + "Action:\u001b[0m\n", "\n", - "\u001B[1m> Finished chain.\u001B[0m\n" + "\u001b[1m> Finished chain.\u001b[0m\n" ] }, { diff --git a/docs/extras/modules/model_io/models/llms/integrations/clarifai.ipynb b/docs/extras/modules/model_io/models/llms/integrations/clarifai.ipynb index 91ee3999bd044..f2fca728b71af 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/clarifai.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/clarifai.ipynb @@ -65,7 +65,7 @@ } ], "source": [ - "# Please login and get your API key from https://clarifai.com/settings/security \n", + "# Please login and get your API key from https://clarifai.com/settings/security\n", "from getpass import getpass\n", "\n", "CLARIFAI_PAT = getpass()" @@ -130,9 +130,9 @@ "metadata": {}, "outputs": [], "source": [ - "USER_ID = 'openai'\n", - "APP_ID = 'chat-completion'\n", - "MODEL_ID = 'GPT-3_5-turbo'\n", + "USER_ID = \"openai\"\n", + "APP_ID = \"chat-completion\"\n", + "MODEL_ID = \"GPT-3_5-turbo\"\n", "\n", "# You can provide a specific model version as the model_version_id arg.\n", "# MODEL_VERSION_ID = \"MODEL_VERSION_ID\"" @@ -148,7 +148,9 @@ "outputs": [], "source": [ "# Initialize a Clarifai LLM\n", - "clarifai_llm = Clarifai(pat=CLARIFAI_PAT, user_id=USER_ID, app_id=APP_ID, model_id=MODEL_ID)" + "clarifai_llm = Clarifai(\n", + " pat=CLARIFAI_PAT, user_id=USER_ID, app_id=APP_ID, model_id=MODEL_ID\n", + ")" ] }, { diff --git a/docs/extras/modules/model_io/models/llms/integrations/huggingface_hub.ipynb b/docs/extras/modules/model_io/models/llms/integrations/huggingface_hub.ipynb index 499652d263676..673d2e91c0a35 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/huggingface_hub.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/huggingface_hub.ipynb @@ -165,7 +165,9 @@ } ], "source": [ - "llm = HuggingFaceHub(repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64})\n", + "llm = HuggingFaceHub(\n", + " repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64}\n", + ")\n", "llm_chain = LLMChain(prompt=prompt, llm=llm)\n", "\n", "print(llm_chain.run(question))" @@ -211,7 +213,9 @@ } ], "source": [ - "llm = HuggingFaceHub(repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64})\n", + "llm = HuggingFaceHub(\n", + " repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64}\n", + ")\n", "llm_chain = LLMChain(prompt=prompt, llm=llm)\n", "print(llm_chain.run(question))" ] @@ -245,7 +249,9 @@ "metadata": {}, "outputs": [], "source": [ - "llm = HuggingFaceHub(repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64})\n", + "llm = HuggingFaceHub(\n", + " repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64}\n", + ")\n", "llm_chain = LLMChain(prompt=prompt, llm=llm)\n", "print(llm_chain.run(question))" ] @@ -277,7 +283,9 @@ "metadata": {}, "outputs": [], "source": [ - "llm = HuggingFaceHub(repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64})\n", + "llm = HuggingFaceHub(\n", + " repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64}\n", + ")\n", "llm_chain = LLMChain(prompt=prompt, llm=llm)\n", "print(llm_chain.run(question))" ] @@ -309,7 +317,9 @@ "metadata": {}, "outputs": [], "source": [ - "llm = HuggingFaceHub(repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64})\n", + "llm = HuggingFaceHub(\n", + " repo_id=repo_id, model_kwargs={\"temperature\": 0.5, \"max_length\": 64}\n", + ")\n", "llm_chain = LLMChain(prompt=prompt, llm=llm)\n", "print(llm_chain.run(question))" ] diff --git a/docs/extras/modules/model_io/models/llms/integrations/llamacpp.ipynb b/docs/extras/modules/model_io/models/llms/integrations/llamacpp.ipynb index b8a1e86ab2ea1..cbf2a05c7b83b 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/llamacpp.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/llamacpp.ipynb @@ -398,7 +398,7 @@ " model_path=\"./ggml-model-q4_0.bin\",\n", " n_gpu_layers=n_gpu_layers,\n", " n_batch=n_batch,\n", - " f16_kv=True, # MUST set to True, otherwise you will run into problem after a couple of calls\n", + " f16_kv=True, # MUST set to True, otherwise you will run into problem after a couple of calls\n", " callback_manager=callback_manager,\n", " verbose=True,\n", ")" diff --git a/docs/extras/modules/model_io/models/llms/integrations/octoai.ipynb b/docs/extras/modules/model_io/models/llms/integrations/octoai.ipynb index 90fd953f52a52..f49ca65da6ca1 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/octoai.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/octoai.ipynb @@ -60,15 +60,15 @@ "outputs": [], "source": [ "llm = OctoAIEndpoint(\n", - " model_kwargs={\n", - " \"max_new_tokens\": 200,\n", - " \"temperature\": 0.75,\n", - " \"top_p\": 0.95,\n", - " \"repetition_penalty\": 1,\n", - " \"seed\": None,\n", - " \"stop\": [],\n", - " },\n", - " )" + " model_kwargs={\n", + " \"max_new_tokens\": 200,\n", + " \"temperature\": 0.75,\n", + " \"top_p\": 0.95,\n", + " \"repetition_penalty\": 1,\n", + " \"seed\": None,\n", + " \"stop\": [],\n", + " },\n", + ")" ] }, { diff --git a/docs/extras/modules/model_io/models/llms/integrations/openllm.ipynb b/docs/extras/modules/model_io/models/llms/integrations/openllm.ipynb index 400ce1b56eddf..9038ef262a102 100644 --- a/docs/extras/modules/model_io/models/llms/integrations/openllm.ipynb +++ b/docs/extras/modules/model_io/models/llms/integrations/openllm.ipynb @@ -56,7 +56,7 @@ "source": [ "from langchain.llms import OpenLLM\n", "\n", - "server_url = \"http://localhost:3000\" # Replace with remote host if you are running on a remote server \n", + "server_url = \"http://localhost:3000\" # Replace with remote host if you are running on a remote server\n", "llm = OpenLLM(server_url=server_url)" ] }, diff --git a/docs/extras/use_cases/code/twitter-the-algorithm-analysis-deeplake.ipynb b/docs/extras/use_cases/code/twitter-the-algorithm-analysis-deeplake.ipynb index 66208a9213701..548780ef1e81d 100644 --- a/docs/extras/use_cases/code/twitter-the-algorithm-analysis-deeplake.ipynb +++ b/docs/extras/use_cases/code/twitter-the-algorithm-analysis-deeplake.ipynb @@ -200,7 +200,6 @@ " dataset_path=\"hub://davitbun/twitter-algorithm\",\n", " read_only=True,\n", " embedding_function=embeddings,\n", - " \n", ")" ] }, diff --git a/docs/extras/use_cases/question_answering/document-context-aware-QA.ipynb b/docs/extras/use_cases/question_answering/document-context-aware-QA.ipynb index 7969cab51a118..498639df375ac 100644 --- a/docs/extras/use_cases/question_answering/document-context-aware-QA.ipynb +++ b/docs/extras/use_cases/question_answering/document-context-aware-QA.ipynb @@ -37,10 +37,11 @@ "source": [ "# Load Notion page as a markdownfile file\n", "from langchain.document_loaders import NotionDirectoryLoader\n", - "path='../Notion_DB/'\n", + "\n", + "path = \"../Notion_DB/\"\n", "loader = NotionDirectoryLoader(path)\n", "docs = loader.load()\n", - "md_file=docs[0].page_content" + "md_file = docs[0].page_content" ] }, { @@ -52,6 +53,7 @@ "source": [ "# Let's create groups based on the section headers in our page\n", "from langchain.text_splitter import MarkdownHeaderTextSplitter\n", + "\n", "headers_to_split_on = [\n", " (\"###\", \"Section\"),\n", "]\n", @@ -76,9 +78,12 @@ "source": [ "# Define our text splitter\n", "from langchain.text_splitter import RecursiveCharacterTextSplitter\n", + "\n", "chunk_size = 500\n", "chunk_overlap = 0\n", - "text_splitter = RecursiveCharacterTextSplitter(chunk_size=chunk_size, chunk_overlap=chunk_overlap)\n", + "text_splitter = RecursiveCharacterTextSplitter(\n", + " chunk_size=chunk_size, chunk_overlap=chunk_overlap\n", + ")\n", "all_splits = text_splitter.split_documents(md_header_splits)" ] }, @@ -99,7 +104,7 @@ "metadata": {}, "outputs": [], "source": [ - "! pip install chromadb " + "! pip install chromadb" ] }, { @@ -112,8 +117,8 @@ "# Build vectorstore and keep the metadata\n", "from langchain.embeddings import OpenAIEmbeddings\n", "from langchain.vectorstores import Chroma\n", - "vectorstore = Chroma.from_documents(documents=all_splits,\n", - " embedding=OpenAIEmbeddings())" + "\n", + "vectorstore = Chroma.from_documents(documents=all_splits, embedding=OpenAIEmbeddings())" ] }, { @@ -131,7 +136,7 @@ "metadata": {}, "outputs": [], "source": [ - "# Create retriever \n", + "# Create retriever\n", "from langchain.llms import OpenAI\n", "from langchain.retrievers.self_query.base import SelfQueryRetriever\n", "from langchain.chains.query_constructor.base import AttributeInfo\n", @@ -148,7 +153,9 @@ "\n", "# Define self query retriver\n", "llm = OpenAI(temperature=0)\n", - "retriever = SelfQueryRetriever.from_llm(llm, vectorstore, document_content_description, metadata_field_info, verbose=True)" + "retriever = SelfQueryRetriever.from_llm(\n", + " llm, vectorstore, document_content_description, metadata_field_info, verbose=True\n", + ")" ] }, { @@ -297,8 +304,9 @@ "source": [ "from langchain.chains import RetrievalQA\n", "from langchain.chat_models import ChatOpenAI\n", + "\n", "llm = ChatOpenAI(model_name=\"gpt-3.5-turbo\", temperature=0)\n", - "qa_chain = RetrievalQA.from_chain_type(llm,retriever=retriever)\n", + "qa_chain = RetrievalQA.from_chain_type(llm, retriever=retriever)\n", "qa_chain.run(\"Summarize the Testing section of the document\")" ] } diff --git a/docs/extras/use_cases/question_answering/semantic-search-over-chat.ipynb b/docs/extras/use_cases/question_answering/semantic-search-over-chat.ipynb index 53a27d7da2eb4..c877a2a524683 100644 --- a/docs/extras/use_cases/question_answering/semantic-search-over-chat.ipynb +++ b/docs/extras/use_cases/question_answering/semantic-search-over-chat.ipynb @@ -62,7 +62,7 @@ "from langchain.llms import OpenAI\n", "\n", "os.environ[\"OPENAI_API_KEY\"] = getpass.getpass(\"OpenAI API Key:\")\n", - "activeloop_token = getpass.getpass(\"Activeloop Token:\")\n", + "activeloop_token = getpass.getpass(\"Activeloop Token:\")\n", "os.environ[\"ACTIVELOOP_TOKEN\"] = activeloop_token\n", "os.environ[\"ACTIVELOOP_ORG\"] = getpass.getpass(\"Activeloop Org:\")\n", "\n", diff --git a/poetry.lock b/poetry.lock index 553f424479933..432f751ef7fcb 100644 --- a/poetry.lock +++ b/poetry.lock @@ -1006,10 +1006,12 @@ files = [ [package.dependencies] click = ">=8.0.0" +ipython = {version = ">=7.8.0", optional = true, markers = "extra == \"jupyter\""} mypy-extensions = ">=0.4.3" packaging = ">=22.0" pathspec = ">=0.9.0" platformdirs = ">=2" +tokenize-rt = {version = ">=3.2.0", optional = true, markers = "extra == \"jupyter\""} tomli = {version = ">=1.1.0", markers = "python_version < \"3.11\""} typing-extensions = {version = ">=3.10.0.0", markers = "python_version < \"3.10\""} @@ -2659,6 +2661,25 @@ dev = ["pre-commit (>=2.17.0,<3.0.0)", "ruff (==0.0.138)", "uvicorn[standard] (> doc = ["mdx-include (>=1.4.1,<2.0.0)", "mkdocs (>=1.1.2,<2.0.0)", "mkdocs-markdownextradata-plugin (>=0.1.7,<0.3.0)", "mkdocs-material (>=8.1.4,<9.0.0)", "pyyaml (>=5.3.1,<7.0.0)", "typer-cli (>=0.0.13,<0.0.14)", "typer[all] (>=0.6.1,<0.8.0)"] test = ["anyio[trio] (>=3.2.1,<4.0.0)", "black (==23.1.0)", "coverage[toml] (>=6.5.0,<8.0)", "databases[sqlite] (>=0.3.2,<0.7.0)", "email-validator (>=1.1.1,<2.0.0)", "flask (>=1.1.2,<3.0.0)", "httpx (>=0.23.0,<0.24.0)", "isort (>=5.0.6,<6.0.0)", "mypy (==0.982)", "orjson (>=3.2.1,<4.0.0)", "passlib[bcrypt] (>=1.7.2,<2.0.0)", "peewee (>=3.13.3,<4.0.0)", "pytest (>=7.1.3,<8.0.0)", "python-jose[cryptography] (>=3.3.0,<4.0.0)", "python-multipart (>=0.0.5,<0.0.7)", "pyyaml (>=5.3.1,<7.0.0)", "ruff (==0.0.138)", "sqlalchemy (>=1.3.18,<1.4.43)", "types-orjson (==3.6.2)", "types-ujson (==5.7.0.1)", "ujson (>=4.0.1,!=4.0.2,!=4.1.0,!=4.2.0,!=4.3.0,!=5.0.0,!=5.1.0,<6.0.0)"] +[[package]] +name = "fastcore" +version = "1.4.2" +description = "Python supercharged for fastai development" +category = "dev" +optional = false +python-versions = ">=3.7" +files = [ + {file = "fastcore-1.4.2-py3-none-any.whl", hash = "sha256:86c31395a87ea429c35f9291e826098f525684a3a6555238448a371274224ddb"}, + {file = "fastcore-1.4.2.tar.gz", hash = "sha256:43bb895507788168317f28cf82031c5ce1796d95a229fc515c10bd90f2355a37"}, +] + +[package.dependencies] +packaging = "*" +pip = "*" + +[package.extras] +dev = ["matplotlib", "nbdev (>=0.2.39)", "numpy", "pandas", "pillow", "torch"] + [[package]] name = "fastjsonschema" version = "2.17.1" @@ -2674,6 +2695,25 @@ files = [ [package.extras] devel = ["colorama", "json-spec", "jsonschema", "pylint", "pytest", "pytest-benchmark", "pytest-cache", "validictory"] +[[package]] +name = "fastrelease" +version = "0.1.17" +description = "Simplified releases using GitHub Issues" +category = "dev" +optional = false +python-versions = ">=3.6" +files = [ + {file = "fastrelease-0.1.17-py3-none-any.whl", hash = "sha256:8b5bbaa9a566fee9c08bbc7cc8fb052a04499a76b464a8b0669707843cb15e2f"}, + {file = "fastrelease-0.1.17.tar.gz", hash = "sha256:c4c6717dcb8c5b37496511dd2a3f97f810b70e1350380b6ae023bb15757b6a63"}, +] + +[package.dependencies] +fastcore = ">=1.3.13" +ghapi = "*" +packaging = "*" +pip = "*" +pyyaml = "*" + [[package]] name = "feedparser" version = "6.0.10" @@ -2966,6 +3006,26 @@ files = [ click = "*" six = "*" +[[package]] +name = "ghapi" +version = "0.1.22" +description = "A python client for the GitHub API" +category = "dev" +optional = false +python-versions = ">=3.6" +files = [ + {file = "ghapi-0.1.22-py3-none-any.whl", hash = "sha256:fba8d57dfc2992d97fe93eaa12e80b9becbed7f13ac6cdcd1c85283c68b04505"}, + {file = "ghapi-0.1.22.tar.gz", hash = "sha256:fbe31684c141767a62899020fff8c6922a8ecaadd6d4614f0673242939cbb655"}, +] + +[package.dependencies] +fastcore = "*" +packaging = "*" +pip = "*" + +[package.extras] +dev = ["jsonref"] + [[package]] name = "gitdb" version = "4.0.10" @@ -4387,27 +4447,28 @@ testing = ["coverage", "ipykernel", "jupytext", "matplotlib", "nbdime", "nbforma [[package]] name = "jupyter-client" -version = "8.2.0" +version = "7.4.9" description = "Jupyter protocol implementation and client libraries" category = "dev" optional = false -python-versions = ">=3.8" +python-versions = ">=3.7" files = [ - {file = "jupyter_client-8.2.0-py3-none-any.whl", hash = "sha256:b18219aa695d39e2ad570533e0d71fb7881d35a873051054a84ee2a17c4b7389"}, - {file = "jupyter_client-8.2.0.tar.gz", hash = "sha256:9fe233834edd0e6c0aa5f05ca2ab4bdea1842bfd2d8a932878212fc5301ddaf0"}, + {file = "jupyter_client-7.4.9-py3-none-any.whl", hash = "sha256:214668aaea208195f4c13d28eb272ba79f945fc0cf3f11c7092c20b2ca1980e7"}, + {file = "jupyter_client-7.4.9.tar.gz", hash = "sha256:52be28e04171f07aed8f20e1616a5a552ab9fee9cbbe6c1896ae170c3880d392"}, ] [package.dependencies] -importlib-metadata = {version = ">=4.8.3", markers = "python_version < \"3.10\""} -jupyter-core = ">=4.12,<5.0.0 || >=5.1.0" +entrypoints = "*" +jupyter-core = ">=4.9.2" +nest-asyncio = ">=1.5.4" python-dateutil = ">=2.8.2" pyzmq = ">=23.0" tornado = ">=6.2" -traitlets = ">=5.3" +traitlets = "*" [package.extras] -docs = ["ipykernel", "myst-parser", "pydata-sphinx-theme", "sphinx (>=4)", "sphinx-autodoc-typehints", "sphinxcontrib-github-alt", "sphinxcontrib-spelling"] -test = ["coverage", "ipykernel (>=6.14)", "mypy", "paramiko", "pre-commit", "pytest", "pytest-cov", "pytest-jupyter[client] (>=0.4.1)", "pytest-timeout"] +doc = ["ipykernel", "myst-parser", "sphinx (>=1.3.6)", "sphinx-rtd-theme", "sphinxcontrib-github-alt"] +test = ["codecov", "coverage", "ipykernel (>=6.12)", "ipython", "mypy", "pre-commit", "pytest", "pytest-asyncio (>=0.18)", "pytest-cov", "pytest-timeout"] [[package]] name = "jupyter-console" @@ -5808,6 +5869,52 @@ serve = ["tornado (>=6.1)"] test = ["ipykernel", "ipywidgets (>=7)", "pre-commit", "pytest", "pytest-dependency"] webpdf = ["pyppeteer (>=1,<1.1)"] +[[package]] +name = "nbdev" +version = "1.2.0" +description = "Writing a library entirely in notebooks" +category = "dev" +optional = false +python-versions = ">=3.6" +files = [ + {file = "nbdev-1.2.0-py3-none-any.whl", hash = "sha256:236bacb23d241e1addfa683d6c3466d3ff960f0bad2639f0142afdfe06daa4f8"}, + {file = "nbdev-1.2.0.tar.gz", hash = "sha256:474b708beef23e89665b695d304f62cd0458703e889cbe2696ae027cf299714e"}, +] + +[package.dependencies] +fastcore = ">=1.3.21" +fastrelease = "*" +ghapi = "*" +ipykernel = "*" +jupyter = "*" +jupyter-client = "<8" +nbconvert = ">=6.4.1" +nbformat = ">=4.4.0" +packaging = "*" +pip = "*" +pyyaml = "*" + +[[package]] +name = "nbdoc" +version = "0.0.82" +description = "Generate beautiful, testable documentation with Jupyter Notebooks" +category = "dev" +optional = false +python-versions = ">=3.8" +files = [ + {file = "nbdoc-0.0.82-py3-none-any.whl", hash = "sha256:84f57e0c20b389eb748eb2055d55d5698b2f44fdef455943d396112d26103fb9"}, + {file = "nbdoc-0.0.82.tar.gz", hash = "sha256:234b785e710025357d66c90be0bf7d620a7a507786380030d749b1c4c5146600"}, +] + +[package.dependencies] +black = {version = ">=22.1.0", extras = ["jupyter"]} +fastcore = "1.4.2" +nbconvert = ">=6.4.1" +nbdev = "1.2.0" +numpydoc = "1.2" +packaging = "*" +pip = "*" + [[package]] name = "nbformat" version = "5.9.0" @@ -6153,6 +6260,25 @@ files = [ {file = "numpy-1.24.3.tar.gz", hash = "sha256:ab344f1bf21f140adab8e47fdbc7c35a477dc01408791f8ba00d018dd0bc5155"}, ] +[[package]] +name = "numpydoc" +version = "1.2" +description = "Sphinx extension to support docstrings in Numpy format" +category = "dev" +optional = false +python-versions = ">=3.7" +files = [ + {file = "numpydoc-1.2-py3-none-any.whl", hash = "sha256:3ecbb9feae080031714b63128912988ebdfd4c582a085d25b8d9f7ac23c2d9ef"}, + {file = "numpydoc-1.2.tar.gz", hash = "sha256:0cec233740c6b125913005d16e8a9996e060528afcb8b7cad3f2706629dfd6f7"}, +] + +[package.dependencies] +Jinja2 = ">=2.10" +sphinx = ">=1.8" + +[package.extras] +testing = ["matplotlib", "pytest", "pytest-cov"] + [[package]] name = "nvidia-cublas-cu11" version = "11.10.3.66" @@ -7179,7 +7305,7 @@ name = "pip" version = "23.1.2" description = "The PyPA recommended tool for installing Python packages." category = "main" -optional = true +optional = false python-versions = ">=3.7" files = [ {file = "pip-23.1.2-py3-none-any.whl", hash = "sha256:3ef6ac33239e4027d9a5598a381b9d30880a1477e50039db2eac6e8a8f6d1b18"}, @@ -11047,6 +11173,18 @@ webencodings = ">=0.4" doc = ["sphinx", "sphinx_rtd_theme"] test = ["flake8", "isort", "pytest"] +[[package]] +name = "tokenize-rt" +version = "5.1.0" +description = "A wrapper around the stdlib `tokenize` which roundtrips." +category = "dev" +optional = false +python-versions = ">=3.8" +files = [ + {file = "tokenize_rt-5.1.0-py2.py3-none-any.whl", hash = "sha256:9b7bb843e77dd6ed0be5564bfaaba200083911e0497841cd3e9235a6a9794d74"}, + {file = "tokenize_rt-5.1.0.tar.gz", hash = "sha256:08f0c2daa94c4052e53c2fcaa8e32585e6ae9bdfc800974092d031401694e002"}, +] + [[package]] name = "tokenizers" version = "0.13.3" @@ -12562,4 +12700,4 @@ text-helpers = ["chardet"] [metadata] lock-version = "2.0" python-versions = ">=3.8.1,<4.0" -content-hash = "b2ccab03db87c42aeed22fdba0c6bae45db6e6968074572561ebddd58e5ce910" +content-hash = "8bb95a90cfff1af5cd7e485a3f271db72de49f4af95bcf0a907ae00384ac35ed" diff --git a/pyproject.toml b/pyproject.toml index b950afbd00e78..e7d206c73882a 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -133,6 +133,7 @@ toml = "^0.10.2" myst-nb = "^0.17.1" linkchecker = "^10.2.1" sphinx-copybutton = "^0.5.1" +nbdoc = "^0.0.82" [tool.poetry.group.test.dependencies] # The only dependencies that should be added are