From 530dbbb22656300f55e238c74513e8caa1671fbf Mon Sep 17 00:00:00 2001
From: Florent <48032461+FlorentLvr@users.noreply.github.com>
Date: Fri, 4 Oct 2024 09:53:28 +0200
Subject: [PATCH] feat: add notebook init
---
Pennylane/Pennylane_List_all_categories.ipynb | 239 ++++++++++++++++++
Pennylane/Pennylane_List_all_customers.ipynb | 238 +++++++++++++++++
.../Pennylane_List_customer_invoices.ipynb | 229 +++++++++++++++++
3 files changed, 706 insertions(+)
create mode 100644 Pennylane/Pennylane_List_all_categories.ipynb
create mode 100644 Pennylane/Pennylane_List_all_customers.ipynb
create mode 100644 Pennylane/Pennylane_List_customer_invoices.ipynb
diff --git a/Pennylane/Pennylane_List_all_categories.ipynb b/Pennylane/Pennylane_List_all_categories.ipynb
new file mode 100644
index 0000000000..0430c8e2a8
--- /dev/null
+++ b/Pennylane/Pennylane_List_all_categories.ipynb
@@ -0,0 +1,239 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "1ec65662-8eb6-4a98-a16e-ffc3729252b6",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2021-02-23T14:22:16.610471Z",
+ "iopub.status.busy": "2021-02-23T14:22:16.610129Z",
+ "iopub.status.idle": "2021-02-23T14:22:16.627784Z",
+ "shell.execute_reply": "2021-02-23T14:22:16.626866Z",
+ "shell.execute_reply.started": "2021-02-23T14:22:16.610384Z"
+ },
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ ""
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "hairy-interstate",
+ "metadata": {},
+ "source": [
+ "# Pennylane - List all categories"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "db03090b-015f-4b1b-8c7c-ba11f37d60b5",
+ "metadata": {},
+ "source": [
+ "**Tags:** #pennylane #list #categories #snippet"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "c54c97eb-8d4d-417c-a402-7adf5327d7fb",
+ "metadata": {},
+ "source": [
+ "**Author:** [Florent Ravenel](https://www.linkedin.com/in/florent-ravenel/)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "ed962863-54e5-48e4-aa48-877adeba86fc",
+ "metadata": {},
+ "source": [
+ "**Description:** This endpoint returns a list of categories."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "fdcf05b5-17d7-4c11-88ec-f722cf264a7f",
+ "metadata": {},
+ "source": [
+ "## Input"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "75da13af-72c2-44b9-8c06-ed3bfa4700ac",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2022-08-31T10:54:23.866665Z",
+ "iopub.status.busy": "2022-08-31T10:54:23.866431Z",
+ "iopub.status.idle": "2022-08-31T10:54:23.871270Z",
+ "shell.execute_reply": "2022-08-31T10:54:23.870705Z",
+ "shell.execute_reply.started": "2022-08-31T10:54:23.866641Z"
+ },
+ "tags": []
+ },
+ "source": [
+ "### Import libraries"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b5605c12-6814-4d98-99b0-aaaa4526014f",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "import requests\n",
+ "import pandas as pd\n",
+ "import naas_python #to use this lib create your account on naas.ai"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "1b6ad1a8-308e-4778-963c-fc21d492a1a9",
+ "metadata": {},
+ "source": [
+ "### Setup variables"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "06d385f7-6b96-4e95-8721-b02ef7c52c83",
+ "metadata": {
+ "tags": [
+ "parameters"
+ ]
+ },
+ "outputs": [],
+ "source": [
+ "api_token = naas_python.secret.get(\"PENNYLANE_API_TOKEN\").value or \"YOUR_PENNYLANE_API_TOKEN\" # if you don't have a naas.ai account, add api_token as string"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "e2b06c06-c20d-4d1a-a228-dca532603925",
+ "metadata": {},
+ "source": [
+ "## Model"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "14cd5a2a-8e0a-45f6-a31c-f487950db30d",
+ "metadata": {},
+ "source": [
+ "### List all categories"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "4a62312c-53f7-4285-b1fd-5dde2592022c",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "def list_all_catgories(\n",
+ " api_token,\n",
+ " per_page=50,\n",
+ " sort=None,\n",
+ " filter=None,\n",
+ "):\n",
+ " url = \"https://app.pennylane.com/api/external/v1/categories\"\n",
+ " headers = {\n",
+ " \"Accept\": \"application/json\",\n",
+ " \"Authorization\": f\"Bearer {api_token}\"\n",
+ " }\n",
+ " data = []\n",
+ " page = 1\n",
+ " while True:\n",
+ " # Get data\n",
+ " res_json = []\n",
+ " params = {\n",
+ " \"page\": page,\n",
+ " \"per_page\": per_page,\n",
+ " }\n",
+ " res = requests.get(url, headers=headers, params=params)\n",
+ " res.raise_for_status()\n",
+ " if res.status_code == 200:\n",
+ " result = res.json().get(\"categories\")\n",
+ "\n",
+ " # Concat result\n",
+ " if len(result) > 0:\n",
+ " data += result\n",
+ " page += 1\n",
+ " else:\n",
+ " break\n",
+ " return data\n",
+ "\n",
+ "result = list_all_catgories(api_token)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "21da518a-e9a5-4655-87a2-52e005f31dbe",
+ "metadata": {},
+ "source": [
+ "## Output"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "08861687-49bb-4c65-83a3-a483a8c4b708",
+ "metadata": {
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ "### Display result"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b123c08c-124a-44ac-bc44-fc72a7768434",
+ "metadata": {
+ "papermill": {},
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "df = pd.DataFrame(result)\n",
+ "print(\"Rows:\", len(df))\n",
+ "df.head(5)"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "078e5821-d264-48b4-a1d1-7bfbc1c05490",
+ "metadata": {},
+ "outputs": [],
+ "source": []
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3",
+ "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.9.6"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}
diff --git a/Pennylane/Pennylane_List_all_customers.ipynb b/Pennylane/Pennylane_List_all_customers.ipynb
new file mode 100644
index 0000000000..bbf44625de
--- /dev/null
+++ b/Pennylane/Pennylane_List_all_customers.ipynb
@@ -0,0 +1,238 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "1ec65662-8eb6-4a98-a16e-ffc3729252b6",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2021-02-23T14:22:16.610471Z",
+ "iopub.status.busy": "2021-02-23T14:22:16.610129Z",
+ "iopub.status.idle": "2021-02-23T14:22:16.627784Z",
+ "shell.execute_reply": "2021-02-23T14:22:16.626866Z",
+ "shell.execute_reply.started": "2021-02-23T14:22:16.610384Z"
+ },
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ ""
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "hairy-interstate",
+ "metadata": {},
+ "source": [
+ "# Pennylane - List all customers"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "db03090b-015f-4b1b-8c7c-ba11f37d60b5",
+ "metadata": {},
+ "source": [
+ "**Tags:** #pennylane #list #customers #snippet"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "c54c97eb-8d4d-417c-a402-7adf5327d7fb",
+ "metadata": {},
+ "source": [
+ "**Author:** [Florent Ravenel](https://www.linkedin.com/in/florent-ravenel/)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "ed962863-54e5-48e4-aa48-877adeba86fc",
+ "metadata": {},
+ "source": [
+ "**Description:** This endpoint returns a list of customers corresponding to the filter provided."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "fdcf05b5-17d7-4c11-88ec-f722cf264a7f",
+ "metadata": {},
+ "source": [
+ "## Input"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "75da13af-72c2-44b9-8c06-ed3bfa4700ac",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2022-08-31T10:54:23.866665Z",
+ "iopub.status.busy": "2022-08-31T10:54:23.866431Z",
+ "iopub.status.idle": "2022-08-31T10:54:23.871270Z",
+ "shell.execute_reply": "2022-08-31T10:54:23.870705Z",
+ "shell.execute_reply.started": "2022-08-31T10:54:23.866641Z"
+ },
+ "tags": []
+ },
+ "source": [
+ "### Import libraries"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b5605c12-6814-4d98-99b0-aaaa4526014f",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "import requests\n",
+ "import pandas as pd\n",
+ "import naas_python #to use this lib create your account on naas.ai"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "1b6ad1a8-308e-4778-963c-fc21d492a1a9",
+ "metadata": {},
+ "source": [
+ "### Setup variables"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "06d385f7-6b96-4e95-8721-b02ef7c52c83",
+ "metadata": {
+ "tags": [
+ "parameters"
+ ]
+ },
+ "outputs": [],
+ "source": [
+ "api_token = naas_python.secret.get(\"PENNYLANE_API_TOKEN\").value or \"YOUR_PENNYLANE_API_TOKEN\" # if you don't have a naas.ai account, add api_token as string"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "e2b06c06-c20d-4d1a-a228-dca532603925",
+ "metadata": {},
+ "source": [
+ "## Model"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "14cd5a2a-8e0a-45f6-a31c-f487950db30d",
+ "metadata": {},
+ "source": [
+ "### List all customers"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "4a62312c-53f7-4285-b1fd-5dde2592022c",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "def list_customers(\n",
+ " api_token,\n",
+ " per_page=50,\n",
+ " sort=None,\n",
+ " filter=None,\n",
+ "):\n",
+ " url = \"https://app.pennylane.com/api/external/v1/customers\"\n",
+ " headers = {\n",
+ " \"Accept\": \"application/json\",\n",
+ " \"Authorization\": f\"Bearer {api_token}\"\n",
+ " }\n",
+ " data = []\n",
+ " page = 1\n",
+ " while True:\n",
+ " # Get data\n",
+ " res_json = []\n",
+ " params = {\n",
+ " \"page\": page,\n",
+ " \"per_page\": per_page,\n",
+ " }\n",
+ " res = requests.get(url, headers=headers, params=params)\n",
+ " res.raise_for_status()\n",
+ " if res.status_code == 200:\n",
+ " result = res.json().get(\"customers\")\n",
+ "\n",
+ " # Concat result\n",
+ " if len(result) > 0:\n",
+ " data += result\n",
+ " page += 1\n",
+ " else:\n",
+ " break\n",
+ " return data\n",
+ "\n",
+ "result = list_customers(api_token)\n",
+ "print(\"Customers:\", len(result))"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "21da518a-e9a5-4655-87a2-52e005f31dbe",
+ "metadata": {},
+ "source": [
+ "## Output"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "08861687-49bb-4c65-83a3-a483a8c4b708",
+ "metadata": {
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ "### Display result"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b123c08c-124a-44ac-bc44-fc72a7768434",
+ "metadata": {
+ "papermill": {},
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "result[0]"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "078e5821-d264-48b4-a1d1-7bfbc1c05490",
+ "metadata": {},
+ "outputs": [],
+ "source": []
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3",
+ "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.9.6"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}
diff --git a/Pennylane/Pennylane_List_customer_invoices.ipynb b/Pennylane/Pennylane_List_customer_invoices.ipynb
new file mode 100644
index 0000000000..f4e44a3cb0
--- /dev/null
+++ b/Pennylane/Pennylane_List_customer_invoices.ipynb
@@ -0,0 +1,229 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "1ec65662-8eb6-4a98-a16e-ffc3729252b6",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2021-02-23T14:22:16.610471Z",
+ "iopub.status.busy": "2021-02-23T14:22:16.610129Z",
+ "iopub.status.idle": "2021-02-23T14:22:16.627784Z",
+ "shell.execute_reply": "2021-02-23T14:22:16.626866Z",
+ "shell.execute_reply.started": "2021-02-23T14:22:16.610384Z"
+ },
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ ""
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "hairy-interstate",
+ "metadata": {},
+ "source": [
+ "# Pennylane - List customer invoices"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "db03090b-015f-4b1b-8c7c-ba11f37d60b5",
+ "metadata": {},
+ "source": [
+ "**Tags:** #pennylane #list #customers #invoices #snippet"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "c54c97eb-8d4d-417c-a402-7adf5327d7fb",
+ "metadata": {},
+ "source": [
+ "**Author:** [Florent Ravenel](https://www.linkedin.com/in/florent-ravenel/)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "ed962863-54e5-48e4-aa48-877adeba86fc",
+ "metadata": {},
+ "source": [
+ "**Description:** This endpoint returns the list of customer invoices corresponding to the filter provided."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "fdcf05b5-17d7-4c11-88ec-f722cf264a7f",
+ "metadata": {},
+ "source": [
+ "## Input"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "75da13af-72c2-44b9-8c06-ed3bfa4700ac",
+ "metadata": {
+ "execution": {
+ "iopub.execute_input": "2022-08-31T10:54:23.866665Z",
+ "iopub.status.busy": "2022-08-31T10:54:23.866431Z",
+ "iopub.status.idle": "2022-08-31T10:54:23.871270Z",
+ "shell.execute_reply": "2022-08-31T10:54:23.870705Z",
+ "shell.execute_reply.started": "2022-08-31T10:54:23.866641Z"
+ },
+ "tags": []
+ },
+ "source": [
+ "### Import libraries"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b5605c12-6814-4d98-99b0-aaaa4526014f",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "import requests\n",
+ "import pandas as pd\n",
+ "import naas_python #to use this lib create your account on naas.ai"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "1b6ad1a8-308e-4778-963c-fc21d492a1a9",
+ "metadata": {},
+ "source": [
+ "### Setup variables"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "06d385f7-6b96-4e95-8721-b02ef7c52c83",
+ "metadata": {
+ "tags": [
+ "parameters"
+ ]
+ },
+ "outputs": [],
+ "source": [
+ "api_token = naas_python.secret.get(\"PENNYLANE_API_TOKEN\").value or \"YOUR_PENNYLANE_API_TOKEN\" # if you don't have a naas.ai account, add api_token as string"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "e2b06c06-c20d-4d1a-a228-dca532603925",
+ "metadata": {},
+ "source": [
+ "## Model"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "14cd5a2a-8e0a-45f6-a31c-f487950db30d",
+ "metadata": {},
+ "source": [
+ "### List customer invoices"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "4a62312c-53f7-4285-b1fd-5dde2592022c",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "def list_customer_invoices(\n",
+ " api_token,\n",
+ " per_page=50,\n",
+ " sort=None,\n",
+ " filter=None,\n",
+ "):\n",
+ " url = \"https://app.pennylane.com/api/external/v1/customer_invoices\"\n",
+ " headers = {\n",
+ " \"Accept\": \"application/json\",\n",
+ " \"Authorization\": f\"Bearer {api_token}\"\n",
+ " }\n",
+ " data = []\n",
+ " page = 1\n",
+ " while True:\n",
+ " # Get data\n",
+ " res_json = []\n",
+ " params = {\n",
+ " \"page\": page,\n",
+ " \"per_page\": per_page,\n",
+ " }\n",
+ " res = requests.get(url, headers=headers, params=params)\n",
+ " res.raise_for_status()\n",
+ " if res.status_code == 200:\n",
+ " result = res.json().get(\"invoices\")\n",
+ "\n",
+ " # Concat result\n",
+ " if len(result) > 0:\n",
+ " data += result\n",
+ " page += 1\n",
+ " else:\n",
+ " break\n",
+ " return data\n",
+ "\n",
+ "result = list_customer_invoices(api_token)\n",
+ "print(\"Invoices:\", len(result))"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "21da518a-e9a5-4655-87a2-52e005f31dbe",
+ "metadata": {},
+ "source": [
+ "## Output"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "08861687-49bb-4c65-83a3-a483a8c4b708",
+ "metadata": {
+ "papermill": {},
+ "tags": []
+ },
+ "source": [
+ "### Display result"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "64f90e2b-9159-4362-be14-e4bf3ed22b94",
+ "metadata": {
+ "tags": []
+ },
+ "outputs": [],
+ "source": [
+ "result[0]"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3",
+ "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.9.6"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}