From c3d78266c733f4d3ebe312598b398d447aa0e37e Mon Sep 17 00:00:00 2001 From: st2411020204 Date: Thu, 8 Jan 2026 16:00:12 +0800 Subject: [PATCH] =?UTF-8?q?style:=20=E4=BC=98=E5=8C=96=E7=AC=94=E8=AE=B0?= =?UTF-8?q?=E6=95=B4=E7=90=86=E5=99=A8=E7=9A=84UI=E6=A0=B7=E5=BC=8F?= =?UTF-8?q?=E5=92=8C=E5=93=8D=E5=BA=94=E5=BC=8F=E8=AE=BE=E8=AE=A1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 添加自定义CSS样式改善整体视觉效果,包括: - 全局布局和间距调整 - 卡片、按钮和输入框的交互效果 - 标签和关键词的渐变样式 - 响应式设计适配移动设备 --- README.md | 3 + note_organizer.py | 142 ++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 145 insertions(+) diff --git a/README.md b/README.md index 30c6e57..5cec0ef 100644 --- a/README.md +++ b/README.md @@ -21,6 +21,9 @@ ## 四、开发心得 在开发这个学习笔记整理器的过程中,我们深刻体会到了技术与需求之间的平衡。这个项目的目的是为了帮助学生更好地管理和查询学习笔记,让学习变得更加高效有序。我们面向的主要是在校学生,他们需要记录大量的学习内容,我们希望能提供给他们一个有效的整理和检索工具。项目功能包括笔记的创建、编辑、删除、分类管理、标签系统、智能搜索、内容提炼以及导入导出等核心功能,力求为学生们提供一个简单易用的笔记管理平台。 + 最初我们考虑使用Chainlit框架,因为它在AI交互方面表现突出,但在实际开发过程中发现,虽然Chainlit在对话式交互上有优势,但在笔记管理功能上显得不够完善,而且智能搜索的效果也没有达到预期。为了让搜索更加智能,我们尝试了各种prompt设计,包括语义搜索的prompt,要求AI根据用户查询理解意图而非简单关键词匹配;概括提取的prompt,让AI对搜索结果进行智能总结和关键点提取;意图识别的prompt,用于判断用户是想创建、编辑还是删除笔记;删除意图的prompt,区分删除单个笔记、删除所有笔记还是删除某个分类的笔记;以及笔记识别的prompt,让AI从多个笔记中找到用户指定的目标。这些prompt设计经过多次调整,包括改变temperature参数、调整max_tokens长度、优化system prompt的表述方式,但效果始终不尽如人意,AI经常误解用户意图或返回不相关的内容。 + 最终我们意识到单纯依赖AI并不能解决所有问题,于是转向了更传统但更可靠的解决方案。在搜索功能上,我们结合了关键词匹配和简单的语义分析,虽然不如纯AI搜索那么智能,但准确性和稳定性大大提升。在笔记管理方面,我们采用了传统的CRUD操作配合Streamlit的交互组件,让用户能够通过直观的界面进行操作,而不是完全依赖自然语言交互。这种混合模式既保留了AI的辅助功能,又确保了核心功能的可靠性。经过反复比较和测试,最终选择了Streamlit框架,它在界面设计和功能实现上更加成熟,能够更好地满足我们的需求。 + 这次开发经历让我们对自己的技术能力有了更清晰的认识。如果没有AI的辅助,我们可能根本无法独立完成这样一个项目,我们在编程基础、框架使用、算法设计等方面都存在很多不足。这次经历既让我们看到了AI工具的强大,也让我们明白了自己需要学习的地方还有很多,未来还需要更加努力地提升自己的技术能力。 diff --git a/note_organizer.py b/note_organizer.py index f1d507d..af70a94 100644 --- a/note_organizer.py +++ b/note_organizer.py @@ -7,6 +7,148 @@ from collections import Counter # 1. 页面配置 st.set_page_config(page_title="学习笔记整理器", page_icon="📚", layout="wide") + +# 添加自定义CSS样式 +st.markdown(""" + +""", unsafe_allow_html=True) + st.title("📚 学习笔记整理器") # 文本提炼函数