{"id":14410,"date":"2025-07-06T00:05:35","date_gmt":"2025-07-05T22:05:35","guid":{"rendered":"https:\/\/pythonprogramming.altervista.org\/?p=14410"},"modified":"2025-07-06T00:05:36","modified_gmt":"2025-07-05T22:05:36","slug":"note-taker-with-python-and-tkinter","status":"publish","type":"post","link":"https:\/\/pythonprogramming.altervista.org\/note-taker-with-python-and-tkinter\/","title":{"rendered":"Note  taker with Python and tkinter"},"content":{"rendered":"\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/image.png\"><img loading=\"lazy\" decoding=\"async\" width=\"823\" height=\"662\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/image.png\" alt=\"\" class=\"wp-image-14412\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/image.png 823w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/image-320x257.png 320w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/image-768x618.png 768w\" sizes=\"auto, (max-width: 823px) 100vw, 823px\" \/><\/a><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">Here&#8217;s a post describing the note-taking app:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Tired of cluttered note apps? Here&#8217;s a clean, focused solution.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">This simple desktop app, built with Python, helps you organize your thoughts. Write your notes L in a distraction-free editor. <\/p>\n\n\n\n<p class=\"wp-block-paragraph\">It&#8217;s focused writing and clean formatting, simplified.<\/p>\n\n\n\n<figure class=\"wp-block-video\"><video height=\"666\" style=\"aspect-ratio: 814 \/ 666;\" width=\"814\" controls src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2025\/07\/Registrazione-2025-07-06-000328.mp4\"><\/video><\/figure>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">import tkinter as tk\nimport os\nfrom tkinter import simpledialog, messagebox\nfrom PIL import Image, ImageTk\nfrom ttkthemes import ThemedTk\n\n# my own modules\nfrom codex.binding import binding\nfrom codex.window import window\n\n\nclass Win:\n    def __init__(self, title, version, folder, extension):\n        self.extension = extension\n        self.letter_size = 14  # Adjusted for better default readability\n        self.root = ThemedTk(theme=\"arc\")  # Using a modern theme\n        self.filename = \"\"\n        self.folder = folder\n        self.root.title(f\"{title} v.{version}\")\n        self.root.geometry(\"800x600\") # Set a default size\n\n        window(self)\n        binding(self)\n        self.define_menu()\n        self.menu_voices()\n        self.showlistitems()\n\n    def define_menu(self):\n        self.menubar = tk.Menu(self.root)\n        self.root.config(menu=self.menubar)\n\n    def change_extension(self, ext):\n        self.extension = ext\n        self.showlistitems()\n\n    def menu_voices(self):\n        voices = [\n            [\"About\", lambda: messagebox.showinfo(\"Credits\", \"pythonprogramming.altervista.org \\nv.3.0.0\", parent=self.root)],\n            [\"Blog\", lambda: os.startfile(\"https:\/\/pythonprogramming.altervista.org\/wp-admin\")],\n            [\"PNG\", lambda: self.change_extension(\".png\")]\n        ]\n        for v in voices:\n            self.menubar.add_command(label=v[0], command=v[1])\n\n    def save(self):\n        if self.filename:\n            try:\n                with open(os.path.join(self.folder, self.filename), \"w\", encoding=\"utf-8\") as file:\n                    file.write(self._text.get(\"1.0\", tk.END))\n            except Exception as e:\n                messagebox.showerror(\"Error\", f\"Failed to save file: {e}\")\n        else:\n            messagebox.showwarning(\"Warning\", \"No file selected.\")\n\n    def delete(self):\n        if self.filename:\n            if messagebox.askyesno(\"Confirm Delete\", f\"Are you sure you want to delete {self.filename}?\"):\n                try:\n                    os.remove(os.path.join(self.folder, self.filename))\n                    self._text.delete(\"1.0\", tk.END)\n                    self.filename = \"\"\n                    self.lb_under_banner.config(text=\"\")\n                    self.showlistitems()\n                except Exception as e:\n                    messagebox.showerror(\"Error\", f\"Failed to delete file: {e}\")\n        else:\n            messagebox.showwarning(\"Warning\", \"No file selected to delete.\")\n\n    def input_filename(self, title=\"New File\", sentence=\"Enter a name for the new file (without extension):\"):\n        name = simpledialog.askstring(title, sentence, parent=self.root)\n        return f\"{name}{self.extension}\" if name else \"\"\n\n    def run(self, evt):\n        if self.filename:\n            file_path = os.path.join(self.folder, self.filename)\n            try:\n                os.startfile(file_path)\n            except Exception as e:\n                messagebox.showerror(\"Error\", f\"Could not open file: {e}\")\n\n    def open_folder(self):\n        os.startfile(self.folder)\n\n    def quit(self, evt=None):\n        if messagebox.askyesno(\"Quit\", \"Do you want to save your changes before quitting?\"):\n            self.save()\n        self.root.destroy()\n\n    def newfile(self, evt=None):\n        new_filename = self.input_filename()\n        if new_filename:\n            try:\n                with open(os.path.join(self.folder, new_filename), \"w\") as file:\n                    pass\n                self.showlistitems()\n                # Automatically select the new file\n                for i, item in enumerate(self._lbx.get(0, tk.END)):\n                    if item == new_filename:\n                        self._lbx.selection_set(i)\n                        self.showcontent(None)\n                        break\n            except Exception as e:\n                messagebox.showerror(\"Error\", f\"Could not create file: {e}\")\n\n    def showlistitems(self):\n        self._lbx.delete(0, tk.END)\n        try:\n            list_of_items = [f for f in os.listdir(self.folder) if f.lower().endswith(self.extension.lower())]\n            list_of_items.sort(reverse=True)\n            for item in list_of_items:\n                self._lbx.insert(tk.END, item)\n        except Exception as e:\n            messagebox.showerror(\"Error\", f\"Could not read directory: {e}\")\n\n    def write_in_text(self, text):\n        self._text.delete(\"1.0\", tk.END)\n        self._text.insert(tk.END, text)\n\n    def join(self):\n        # Implementation for joining files can be refined or kept as is\n        pass\n\n    def showcontent(self, evt):\n        selection_indices = self._lbx.curselection()\n        if not selection_indices:\n            return\n\n        selected_index = selection_indices[0]\n        self.filename = self._lbx.get(selected_index)\n        self.lb_under_banner.config(text=f\"Selected: {self.filename}\")\n\n        if self.filename.lower().endswith((\".png\", \".jpg\", \".jpeg\", \".gif\")):\n            # Image handling can be improved\n            messagebox.showinfo(\"Image\", \"Image display can be implemented here.\")\n        else:\n            try:\n                with open(os.path.join(self.folder, self.filename), \"r\", encoding=\"utf-8\") as file:\n                    self.write_in_text(file.read())\n            except Exception as e:\n                messagebox.showerror(\"Error\", f\"Could not read file: {e}\")\n\n    def clear(self):\n        self._text.delete(\"1.0\", tk.END)\n\n    def copy(self):\n        self.root.clipboard_clear()\n        self.root.clipboard_append(self._text.get(\"1.0\", \"end-1c\"))\n\ndef create_chapters_folder(folder):\n    if not os.path.exists(folder):\n        os.makedirs(folder)\n        print(f\"Created folder: {folder}\")\n\nif __name__ == \"__main__\":\n    FOLDER_FOR_FILES = \"snippets\"\n    FILE_EXTENSION = \".txt\"\n    create_chapters_folder(FOLDER_FOR_FILES)\n    ver = \"3.0.0\"\n    win = Win(\"ModernNotes\", ver, folder=FOLDER_FOR_FILES, extension=FILE_EXTENSION)\n    win.root.mainloop()<\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"><!-- se vuoi mettere un testo scorrevole\r\n[hoops name=\"typeWriterGen\"]\r\n\r\npoi metti un id diverso per ogni testo nella stessa pagina\r\n\r\n<div id=\"div01\">\r\n<script>\r\n\r\ntypeWriterGen(\"div01\",\"Esempio di testo scorrevole\");\r\n<\/script>\r\n\r\n-->\r\n<style>\r\n.avatar {\r\n  vertical-align: middle;\r\n  width: 100px;\r\n  height: 100px;\r\n  border-radius: 50%;\r\n}\r\n<\/style>\r\n\r\n<hr>\r\n\r\n<!-- NEWSLETTER LINK -->\r\n<a href=\"https:\/\/docs.google.com\/forms\/d\/e\/1FAIpQLSf7TniIPCWHDzCSGh2dYZaCwDvi9yLKS5ovFdKuK1sdfOvwEg\/viewform\">\r\n<img decoding=\"async\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2023\/08\/image-13.png\" class=\"avatar\">\r\nSubscribe to the <b>newsletter<\/b> for updates<\/a><br>\r\n\r\n<!-- TKINTER TEMPLATE LINK -->\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/tkinter-templates\/\">\r\n<img decoding=\"async\" src=\"https:\/\/i0.wp.com\/pythonprogramming.altervista.org\/wp-content\/uploads\/2023\/07\/image-26.png\" class=\"avatar\">\r\nTkinter templates<\/a><br>\r\n\r\n<!-- MY AVATAR PUT A LINK TO YOUTUBE CHANNEL-->\r\n<iframe loading=\"lazy\" frameborder=\"0\" src=\"https:\/\/itch.io\/embed\/711828\" width=\"552\" height=\"167\"><a href=\"https:\/\/pythonprogrammi.itch.io\/pysnake\">PySnake by PythonProgrammi<\/a><\/iframe>\r\n<br>\r\n<style>\r\n.avatar {\r\n  vertical-align: middle;\r\n  width: 100px;\r\n  height: 100px;\r\n  border-radius: 50%;\r\n}\r\n<\/style>\r\n\r\n\r\n<a href=\"https:\/\/www.youtube.com\/channel\/UCzbxq5e9gLiY-je2-br1rvg\">\r\n\t<img decoding=\"async\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2020\/10\/avatar64x64.png\" alt=\"Avatar\" class=\"avatar\">\r\n\t My youtube channel<\/a><br>\r\n\r\n<br>\r\n\r\nTwitter: <a href=\"https:\/\/twitter.com\/pythonprogrammi\">@pythonprogrammi - python_pygame<\/a>\r\n<h3>Claude's Games<\/h3>\r\n<p><a href=\"https:\/\/pythonprogramming.altervista.org\/random-daily-game-1-arkanoid\/\">Arkanoid<\/a><br>\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/platform-2d-with-pygame-made-with-claude\/\">Platform 2d<\/a><\/p> <!-- videogames made with claude -->\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/artifacts-games-day-1-memory-game\/\">1. Memory game<\/a>\r\n<h4>Videos<\/h4>\r\n<a href=\"https:\/\/youtu.be\/ciLjWWw5pLY\">Speech recognition game<\/a>\r\n<h3>Pygame's Platform Game<\/h3>\r\n\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-5-sounds-and-mixer\/\"><img decoding=\"async\" src=\"https:\/\/i1.wp.com\/pythonprogramming.altervista.org\/wp-content\/uploads\/2020\/01\/climbercover.png?w=557&ssl=1\"\/ width=\"50%\"><\/a>\r\n<script>\r\nvar title = \"Platform Pygame\";\r\n\t\tvar links = [\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-animation-of-a-sprite-v-1-3\/\",\"Animation 1.3\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-sprite-animation-v-2-better-coding-test-it-checking-fps-on-the-screen\/\",\"Animation 1.2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-how-to-display-the-frame-rate-fps-on-the-screen\/\",\"Display Frame rate\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-sprite-animation-update\/\",\"Animation 1.1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platformer-1\/\",\"Pygame Platform Game 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-platform-game-2\/\",\"Pygame Platform 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-3-recap-cheatsheet\/\",\"Pygame PLatform 3 - recap and some Cheat Sheet\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-4-background-and-stuffs\/\",\"Pygame Platform 4 - Background & organizing code\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-5-sounds-and-mixer\/\",\"Pygame Platform 5 - Sounds\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/platform-game-in-detail-part-1\/\",\"Game in detail part 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/map-maker-1-2\/\", \"Map maker 1.2\"]\r\n\t\t];\r\n\t\t<\/script>\r\n<script>\r\n\t\r\nif (typeof next2 != \"undefined\"){let next2 = 0;}\r\n\t\r\nnext2 = 0;\r\n\thtml = \"\";\/\/<b style='color:coral;font-size:1.2em'>Other posts about \" + title + \"<\/b><br>\";\r\nfor (address of links) \r\n{\r\n\r\n\tif (next2 == 1){\r\n\t\thtml += \"<div style='background:coral'>\";\r\n\t\thtml += \"Next link => <a href='\" + address[0] + \"'>\" + address[1] + \"<\/a>\";\r\n\t\thtml += \"<\/div><br>\";\r\n\t\tnext2 = 0;\r\n\t}\r\n\tif (address[0] == document.URL) {\r\n\t\tnext2 = 1;\r\n\t}\r\n}\r\n\r\nif (typeof next != \"undefined\") {let next = 0;}\r\nif (typeof addressStart != \"undefined\") {let addressStart = \"\";}\r\nnext = 0;\r\naddressStart = \"<a href='\";\r\nfor (address of links) {\r\n\tif (next == 1){\r\n\t\thtml += \">>>\" + addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t\tnext = 0;\r\n\t}\r\n\telse if (addressStart + address[0] != document.URL)\r\n\t{\r\n\t\thtml += addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t}\r\n\telse\r\n\t{\r\n\t\tnext = 1;\r\n\t\tnext_address = address[0]\r\n\t\tnext_title = address[1]\r\n\t\thtml += \"<span style='color:gray'>\" + address[1] + \"<\/span><br>\";\r\n\t}\r\n\r\n}\r\n\r\n\thtml += `<span style=\"font-size:8px\">Powered by <a href=\"https:\/\/pythonprogramming.altervista.org\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-2673\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png\" alt=\"\" width=\"70\" height=\"25\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png 156w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2-150x56.png 150w\" sizes=\"auto, (max-width: 70px) 100vw, 70px\" \/>pythonprogramming.altervista.org<\/a><\/span>`\r\n\thtml = \"<div style='background:yellow'>\" + html + \"<\/div>\";\r\n\tdocument.write(html)\r\n<\/script>\r\n\r\n<h3>Other Pygame's posts<\/h3>\r\n\r\n<script>\r\nvar title = \"Pygame's Posts\"\r\nvar links = [\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platformer-1\/\",\"Platform game 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/make-a-platform-game-with-pygame-dafluffypotato\/\",\"DaFluffyPotato Platform Tutorials\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-and-classic-arcade-games-pong\/\",\"Pong Game Full\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-draws-in-colors-app-to-draw-with-pygame\/\",\"PyGameGIF 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-draw-app-with-animation\/\",\"PyGameGIF 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pydraw-2-0-app-to-draw-gif\/\",\"PyDraw 2.0\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-drawing-2\/\",\"Draw with Pygame\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/animation-with-pygame\",\"Sprite animation 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/animation-on-pygame-2-free-characters-and-more-actions\/\",\"Sprite animation 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/starting-with-pygame\/\",\"Starting movements with Pygame\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-3-move-sprite\/\", \"Move a Sprite\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-4-fonts\/\",\"Text and Fonts\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-animate-a-sprite\/\", \"Animate a sprite\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-and-mouse-events\/\",\"Mouse events\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pgp-aka-pygamepresentation-project\/\",\"Pygame presentation\"],\r\n\t[\"https:\/\/pythonprogramming.altervista.org\/moving-the-player-in-pygame-with-key-get_pressed\/\",\"How to use key.get_pressed()\"]\r\n]\r\n<\/script>\r\n\r\n\r\n<script>\r\n\t\r\nif (typeof next2 != \"undefined\"){let next2 = 0;}\r\n\t\r\nnext2 = 0;\r\n\thtml = \"\";\/\/<b style='color:coral;font-size:1.2em'>Other posts about \" + title + \"<\/b><br>\";\r\nfor (address of links) \r\n{\r\n\r\n\tif (next2 == 1){\r\n\t\thtml += \"<div style='background:coral'>\";\r\n\t\thtml += \"Next link => <a href='\" + address[0] + \"'>\" + address[1] + \"<\/a>\";\r\n\t\thtml += \"<\/div><br>\";\r\n\t\tnext2 = 0;\r\n\t}\r\n\tif (address[0] == document.URL) {\r\n\t\tnext2 = 1;\r\n\t}\r\n}\r\n\r\nif (typeof next != \"undefined\") {let next = 0;}\r\nif (typeof addressStart != \"undefined\") {let addressStart = \"\";}\r\nnext = 0;\r\naddressStart = \"<a href='\";\r\nfor (address of links) {\r\n\tif (next == 1){\r\n\t\thtml += \">>>\" + addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t\tnext = 0;\r\n\t}\r\n\telse if (addressStart + address[0] != document.URL)\r\n\t{\r\n\t\thtml += addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t}\r\n\telse\r\n\t{\r\n\t\tnext = 1;\r\n\t\tnext_address = address[0]\r\n\t\tnext_title = address[1]\r\n\t\thtml += \"<span style='color:gray'>\" + address[1] + \"<\/span><br>\";\r\n\t}\r\n\r\n}\r\n\r\n\thtml += `<span style=\"font-size:8px\">Powered by <a href=\"https:\/\/pythonprogramming.altervista.org\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-2673\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png\" alt=\"\" width=\"70\" height=\"25\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png 156w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2-150x56.png 150w\" sizes=\"auto, (max-width: 70px) 100vw, 70px\" \/>pythonprogramming.altervista.org<\/a><\/span>`\r\n\thtml = \"<div style='background:yellow'>\" + html + \"<\/div>\";\r\n\tdocument.write(html)\r\n<\/script><\/p>\n","protected":false},"excerpt":{"rendered":"Here&#8217;s a post describing the note-taking app: Tired of cluttered note apps? Here&#8217;s a clean, focused solution. This simple desktop app, built with \n<a class=\"moretag\" href=\"https:\/\/pythonprogramming.altervista.org\/note-taker-with-python-and-tkinter\/\"> [...]<\/a>","protected":false},"author":1,"featured_media":14412,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_crdt_document":"","footnotes":""},"categories":[1],"tags":[],"class_list":["post-14410","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-examples"],"avopt_banners_inside_post":true,"avopt_banners_on_page":true,"av_copy_from":"","av_sharing_message":"","av_sharing_allowed":true,"av_sharing_on":{"fb":[],"tw":[]},"av_allow_affiliate_banner":false,"av_allow_affiliate_multi_banner":false,"av_show_affiliation_buy_button":false,"av_post_rating":true,"av_have_post_rating_value":false,"av_is_artificial_intelligence_content":false,"_links":{"self":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/14410","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/comments?post=14410"}],"version-history":[{"count":1,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/14410\/revisions"}],"predecessor-version":[{"id":14413,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/14410\/revisions\/14413"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/media\/14412"}],"wp:attachment":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/media?parent=14410"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/categories?post=14410"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/tags?post=14410"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}