{ "cells": [ { "cell_type": "markdown", "id": "b0ed136e-6983-4893-ae1b-b75753af05f8", "metadata": {}, "source": [ "# Google Drive\n", "This notebook covers how to load documents from Google Drive. Currently, only Google Docs are supported.\n", "\n", "## Prerequisites\n", "\n", "1. Create a Google Cloud project or use an existing project\n", "1. Enable the [Google Drive API](https://console.cloud.google.com/flows/enableapi?apiid=drive.googleapis.com)\n", "1. [Authorize credentials for desktop app](https://developers.google.com/drive/api/quickstart/python#authorize_credentials_for_a_desktop_application)\n", "1. `pip install --upgrade google-api-python-client google-auth-httplib2 google-auth-oauthlib`\n", "\n", "## 🧑 Instructions for ingesting your Google Docs data\n", "By default, the `GoogleDriveLoader` expects the `credentials.json` file to be `~/.credentials/credentials.json`, but this is configurable using the `credentials_path` keyword argument. Same thing with `token.json` - `token_path`. Note that `token.json` will be created automatically the first time you use the loader.\n", "\n", "`GoogleDriveLoader` can load from a list of Google Docs document ids or a folder id. You can obtain your folder and document id from the URL:\n", "* Folder: https://drive.google.com/drive/u/0/folders/1yucgL9WGgWZdM1TOuKkeghlPizuzMYb5 -> folder id is `\"1yucgL9WGgWZdM1TOuKkeghlPizuzMYb5\"`\n", "* Document: https://docs.google.com/document/d/1bfaMQ18_i56204VaQDVeAFpqEijJTgvurupdEDiaUQw/edit -> document id is `\"1bfaMQ18_i56204VaQDVeAFpqEijJTgvurupdEDiaUQw\"`" ] }, { "cell_type": "code", "execution_count": 1, "id": "878928a6-a5ae-4f74-b351-64e3b01733fe", "metadata": { "tags": [] }, "outputs": [], "source": [ "from langchain.document_loaders import GoogleDriveLoader" ] }, { "cell_type": "code", "execution_count": 2, "id": "2216c83f-68e4-4d2f-8ea2-5878fb18bbe7", "metadata": { "tags": [] }, "outputs": [], "source": [ "loader = GoogleDriveLoader(\n", " folder_id=\"1yucgL9WGgWZdM1TOuKkeghlPizuzMYb5\",\n", " # Optional: configure whether to recursively fetch files from subfolders. Defaults to False.\n", " recursive=False\n", ")" ] }, { "cell_type": "code", "execution_count": 3, "id": "8f3b6aa0-b45d-4e37-8c50-5bebe70fdb9d", "metadata": { "tags": [] }, "outputs": [], "source": [ "docs = loader.load()" ] } ], "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.9" } }, "nbformat": 4, "nbformat_minor": 5 }