timeline test
This commit is contained in:
@@ -2,118 +2,107 @@
|
||||
"cells": [
|
||||
{
|
||||
"cell_type": "code",
|
||||
"execution_count": 2,
|
||||
"execution_count": null,
|
||||
"id": "090c7992",
|
||||
"metadata": {},
|
||||
"outputs": [
|
||||
{
|
||||
"name": "stdout",
|
||||
"output_type": "stream",
|
||||
"text": [
|
||||
"\n",
|
||||
" im still struggling:\n",
|
||||
" </p>\n",
|
||||
" <p>sudo pacman -S archlinux-keyring</p>\n",
|
||||
" <p>melange:</p>\n",
|
||||
" <ul>\n",
|
||||
" <li><a href=\"/page2/line/lineplot.html\">machine learning with failed hyperparams</a></li>\n",
|
||||
" <li><a href=\"/page2/dblp/bar/index.html\">the dblp dataset in bar plot</a></li>\n",
|
||||
" <li><a href=\"/page2/dblp/edge/index.html\">the dblp dataset with an example of community</a></li>\n",
|
||||
" <li><a href=\"/page2/dblp/full/index.html\">the dblp dataset of 5 years as a graph</a></li>\n",
|
||||
" <li><a href=\"/page2/dblp/time/index.html\">the generated links as a graph</a></li>\n",
|
||||
"\n",
|
||||
" </ul>\n",
|
||||
"\n",
|
||||
"Post 3 updated successfully.\n"
|
||||
]
|
||||
}
|
||||
],
|
||||
"outputs": [],
|
||||
"source": [
|
||||
"import datetime\n",
|
||||
"\n",
|
||||
"# git entry and print\n",
|
||||
"def get_entry(file_path, id):\n",
|
||||
"\n",
|
||||
" # 1. Import the current list to get the latest ID\n",
|
||||
"\n",
|
||||
" # We use a namespace to avoid path issues\n",
|
||||
"\n",
|
||||
" # use a namespace to avoid path issues\n",
|
||||
" namespace = {}\n",
|
||||
"\n",
|
||||
" with open(file_path, 'r') as f:\n",
|
||||
"\n",
|
||||
" with open(file_path, \"r\") as f:\n",
|
||||
" exec(f.read(), namespace)\n",
|
||||
"\n",
|
||||
" posts = namespace.get('BLOG_POSTS', [])\n",
|
||||
" posts = namespace.get(\"BLOG_POSTS\", [])\n",
|
||||
"\n",
|
||||
" for items in posts:\n",
|
||||
"\n",
|
||||
" if items.get(\"id\") == id:\n",
|
||||
"\n",
|
||||
" content = items.get('content')\n",
|
||||
"\n",
|
||||
" content = items.get(\"content\")\n",
|
||||
" print(content)\n",
|
||||
"\n",
|
||||
" return items \n",
|
||||
"\n",
|
||||
" return items\n",
|
||||
"\n",
|
||||
"\n",
|
||||
"def update_entry(file_path, post_id, new_content):\n",
|
||||
" # 1. Load the existing data into memory\n",
|
||||
" namespace = {}\n",
|
||||
" with open(file_path, 'r') as f:\n",
|
||||
" with open(file_path, \"r\") as f:\n",
|
||||
" exec(f.read(), namespace)\n",
|
||||
" \n",
|
||||
" posts = namespace.get('BLOG_POSTS', [])\n",
|
||||
" \n",
|
||||
"\n",
|
||||
" posts = namespace.get(\"BLOG_POSTS\", [])\n",
|
||||
"\n",
|
||||
" # 2. Find and update the specific post\n",
|
||||
" found = False\n",
|
||||
" for post in posts:\n",
|
||||
" if post.get(\"id\") == post_id:\n",
|
||||
" post['content'] = new_content\n",
|
||||
" post[\"content\"] = new_content\n",
|
||||
" # Optional: Update the date or add an \"updated\" field\n",
|
||||
" # post['subtitle'] += \" (Updated)\" \n",
|
||||
" # post['subtitle'] += \" (Updated)\"\n",
|
||||
" found = True\n",
|
||||
" break\n",
|
||||
" \n",
|
||||
"\n",
|
||||
" if not found:\n",
|
||||
" print(f\"Error: Post {post_id} not found.\")\n",
|
||||
" return\n",
|
||||
"\n",
|
||||
" # 3. Write the entire list back to the file\n",
|
||||
" # Using repr() or a loop to format it cleanly\n",
|
||||
" with open(file_path, 'w') as f:\n",
|
||||
" with open(file_path, \"w\") as f:\n",
|
||||
" f.write(\"BLOG_POSTS = [\\n\")\n",
|
||||
" for p in posts:\n",
|
||||
" # Use .get() to provide a default value if the key is missing\n",
|
||||
" display_val = p.get('displayall', False) \n",
|
||||
" data_val = p.get('date', \"?\") \n",
|
||||
" subtitle_val = p.get('subtitle', \"\") \n",
|
||||
" \n",
|
||||
" display_val = p.get(\"displayall\", False)\n",
|
||||
" data_val = p.get(\"date\", \"?\")\n",
|
||||
" subtitle_val = p.get(\"subtitle\", \"\")\n",
|
||||
"\n",
|
||||
" entry = f\"\"\" {{\n",
|
||||
" 'id': {p['id']},\n",
|
||||
" 'title': \"{p['title']}\",\n",
|
||||
" 'id': {p[\"id\"]},\n",
|
||||
" 'title': \"{p[\"title\"]}\",\n",
|
||||
" 'subtitle': \"{subtitle_val}\",\n",
|
||||
" 'date': \"{data_val}\",\n",
|
||||
" 'content': \\\"\\\"\\\"{p['content']}\\\"\\\"\\\",\n",
|
||||
" 'content': \\\"\\\"\\\"{p[\"content\"]}\\\"\\\"\\\",\n",
|
||||
" \"displayall\": {display_val}\n",
|
||||
" }},\\n\"\"\"\n",
|
||||
" f.write(entry)\n",
|
||||
" f.write(\"]\\n\")\n",
|
||||
" \n",
|
||||
"\n",
|
||||
" print(f\"Post {post_id} updated successfully.\")\n",
|
||||
"\n"
|
||||
]
|
||||
},
|
||||
{
|
||||
"cell_type": "code",
|
||||
"execution_count": 5,
|
||||
"id": "7c80d17a",
|
||||
"metadata": {},
|
||||
"outputs": [],
|
||||
"source": [
|
||||
"FIEL_PATH = \"../content/posts.py\"\n",
|
||||
"get_entry(FIEL_PATH, 0)"
|
||||
]
|
||||
},
|
||||
{
|
||||
"cell_type": "code",
|
||||
"execution_count": null,
|
||||
"id": "e2048547",
|
||||
"metadata": {},
|
||||
"outputs": [],
|
||||
"source": [
|
||||
"\n",
|
||||
"# --- Usage Example ---\n",
|
||||
"if __name__ == \"__main__\":\n",
|
||||
" file = '../content/posts.py'\n",
|
||||
" file = \"../content/posts.py\"\n",
|
||||
" target_id = 3\n",
|
||||
" \n",
|
||||
"\n",
|
||||
" # Get the old one first to see it\n",
|
||||
" old_post = get_entry(file, target_id)\n",
|
||||
" \n",
|
||||
"\n",
|
||||
" if old_post:\n",
|
||||
" pass\n",
|
||||
"\n",
|
||||
" new_text=\"\"\"\n",
|
||||
" new_text = \"\"\"\n",
|
||||
" <p>sudo pacman -S archlinux-keyring</p>\n",
|
||||
" <p>sudo pacman -Sc</p>\n",
|
||||
" <p>melange:</p>\n",
|
||||
@@ -128,15 +117,14 @@
|
||||
"\n",
|
||||
"\n",
|
||||
" \"\"\"\n",
|
||||
" \n",
|
||||
" \n",
|
||||
" update_entry(file, target_id, new_text)\n"
|
||||
"\n",
|
||||
" update_entry(file, target_id, new_text)"
|
||||
]
|
||||
}
|
||||
],
|
||||
"metadata": {
|
||||
"kernelspec": {
|
||||
"display_name": "base",
|
||||
"display_name": "graphx",
|
||||
"language": "python",
|
||||
"name": "python3"
|
||||
},
|
||||
@@ -150,7 +138,7 @@
|
||||
"name": "python",
|
||||
"nbconvert_exporter": "python",
|
||||
"pygments_lexer": "ipython3",
|
||||
"version": "3.11.7"
|
||||
"version": "3.11.11"
|
||||
}
|
||||
},
|
||||
"nbformat": 4,
|
||||
|
||||
16
templates/components/timeline.html
Normal file
16
templates/components/timeline.html
Normal file
@@ -0,0 +1,16 @@
|
||||
<div class="max-w-3xl mx-auto px-6 py-16">
|
||||
<ol class="relative border-l border-gray-300">
|
||||
{% for item in timeline %}
|
||||
<li class="mb-10 ml-6">
|
||||
<span
|
||||
class="absolute flex items-center justify-center w-6 h-6 bg-gray-200 rounded-full -left-3"
|
||||
>
|
||||
</span>
|
||||
|
||||
<h3 class="font-semibold text-lg">{{ item.title }}</h3>
|
||||
|
||||
<p class="text-gray-600">{{ item.description }}</p>
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ol>
|
||||
</div>
|
||||
3
templates/posts/post_5.html
Normal file
3
templates/posts/post_5.html
Normal file
@@ -0,0 +1,3 @@
|
||||
<h1 class="text-3xl font-bold mb-8">Project Timeline</h1>
|
||||
|
||||
{% include "components/timeline.html" %}
|
||||
Reference in New Issue
Block a user