Python Quickstart
Learn how to query data from Convex in a Python app.
- Create a Python script folderCreate a folder for your Python script with a virtual environment. python3 -m venv my-app/venv
- Install the Convex client and server librariesTo get started, install the convexnpm package which enables you to write your backend.And also install the convexPython client library andpython-dotenvfor working with.envfiles.cd my-app && npm init -y && npm install convex && venv/bin/pip install convex python-dotenv
- Set up a Convex dev deploymentNext, run npx convex dev. This will prompt you to log in with GitHub, create a project, and save your production and deployment URLs.It will also create a convex/folder for you to write your backend API functions in. Thedevcommand will then continue running to sync your functions with your dev deployment in the cloud.npx convex dev
- Create sample data for your databaseIn a new terminal window, create a sampleData.jsonlfile with some sample data.sampleData.jsonl{"text": "Buy groceries", "isCompleted": true}
 {"text": "Go for a swim", "isCompleted": true}
 {"text": "Integrate Convex", "isCompleted": false}
- Add the sample data to your databaseNow that your project is ready, add a taskstable with the sample data into your Convex database with theimportcommand.npx convex import --table tasks sampleData.jsonl
- Expose a database queryAdd a new file tasks.jsin theconvex/folder with a query function that loads the data.Exporting a query function from this file declares an API function named after the file and the export name, "tasks:get".convex/tasks.jsimport { query } from "./_generated/server";
 export const get = query({
 handler: async ({ db }) => {
 return await db.query("tasks").collect();
 },
 });
- Create a script to load data from ConvexIn a new file main.py, create aConvexClientand use it to fetch from your"tasks:get"API.main.pyimport os
 from convex import ConvexClient
 from dotenv import load_dotenv
 load_dotenv(".env.local")
 CONVEX_URL = os.getenv("CONVEX_URL")
 # or you can hardcode your deployment URL instead
 # CONVEX_URL = "https://happy-otter-123.convex.cloud"
 client = ConvexClient(CONVEX_URL)
 print(client.query("tasks:get"))
 for tasks in client.subscribe("tasks:get"):
 print(tasks)
 # this loop lasts forever, ctrl-c to exit it
- Run the scriptRun the script and see the serialized list of tasks. venv/bin/python -m main
See the docs on PyPI for more details.