首页
/ FreePlane节点创建日期修改技术方案解析

FreePlane节点创建日期修改技术方案解析

2025-06-26 09:38:54作者:廉彬冶Miranda

背景介绍

FreePlane作为一款强大的思维导图工具,其节点管理功能十分完善。在实际使用中,用户经常需要根据时间维度对节点进行管理,例如按创建时间筛选、归档或删除旧节点。然而系统默认的创建时间记录机制可能无法满足某些特殊场景需求。

核心问题

当用户需要将某些历史信息导入FreePlane时,这些信息的实际产生时间往往早于节点创建时间。系统默认的创建时间记录方式会导致时间维度管理失效,因此需要技术手段来修改节点的创建日期属性。

技术解决方案

Groovy脚本方案

FreePlane内置支持Groovy脚本,可直接在节点中执行日期修改操作:

// 基础格式:直接设置指定日期
node.setCreatedAt(Date.parse("yyyy-MM-dd","2023-09-24"))

// 完整示例:包含日期解析和设置
pattern = "yyyy-MM-dd"
input = "2023-12-13"
date = Date.parse(pattern,input)
node.setCreatedAt(date)

实现原理

  1. 使用Date.parse方法解析字符串日期
  2. 通过setCreatedAt方法将解析后的日期对象设置为节点属性
  3. 日期格式需严格匹配"yyyy-MM-dd"模式

注意事项

  • 脚本执行后会返回null,这是正常现象
  • 日期格式错误会导致解析失败
  • 修改后需刷新视图查看效果

Python扩展方案

对于熟悉Python的用户,可以使用freeplane-python-io库实现更复杂的日期管理:

import freeplane
import datetime

mm = freeplane.Mindmap("mindmap.mm")
node = mm.find_nodes(core="节点内容")[0]
timevalue = datetime.datetime.fromisoformat("2023-12-10")
timestamp = str(int(timevalue.timestamp() * 1000))
freeplane.update_date_attribute_in_node(node._node, date=timestamp, key="CREATED")
mm.save("mindmap.mm")

优势

  • 支持批量操作
  • 可结合其他Python数据处理库
  • 适合自动化处理大量节点

应用场景建议

  1. 历史数据归档:将旧资料导入时保持原始时间戳
  2. 时间维度管理:按实际信息产生时间而非录入时间进行管理
  3. 定期清理机制:配合时间筛选功能自动清理过期节点

技术细节说明

  1. 时间格式处理

    • Groovy使用Java的SimpleDateFormat格式
    • 推荐统一使用"yyyy-MM-dd"格式避免混淆
    • 时区默认为系统设置
  2. 脚本执行方式

    • 通过"工具-编辑脚本"菜单执行
    • 可直接在节点属性中保存常用脚本
    • 可创建快捷方式快速调用
  3. 性能考虑

    • 单个节点修改即时生效
    • 批量操作建议使用Python方案
    • 大文件操作前建议备份

总结

登录后查看全文
热门项目推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
144
1.93 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
930
553
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
423
392
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
64
511