如何修改创建时间?

本贴最后更新于 322 天前,其中的信息可能已经时移俗易

如题

印象和 notion 过来的报个到!

笔记的创建时间对我而言是很重要的因素,有什么办法可以修改吗?

这两天从大象和 notion 倒过来大量笔记,创建时间都是这两天的。让我很纠结,茶饭不思!

如我大象的笔记,时间也代表了一种笔记,请问各路大神有没有办法修改啊,在线等,挺急的!!!

image.png

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    22009 引用 • 87757 回帖 • 2 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • muxue 1 评论

    估计得自己改数据库里面的创建时间字段,可以问一下 D 大能不能在笔记本内部新增个改创建时间的功能。

    创建时间是看文档 ID 的,只能通过改 ID 来改创建时间,但直接改 ID 会导致很多问题
    JeffreyChen
  • pinghe

    还不如提个需求,要求支持导入笔记时,保留原始创建时间

    1 回复
  • 这个很赞同,这也是我继续两款同时使用的原因之一。

    如果能做到导入时候同时从 front matter 识别日期时间就太棒了

  • 你从别的软件导出的文件里面,那个导出的文件的创建时间应该也是导出的时间吧……除非是本地的 md 文档还有可能保留原始创建时间

  • 改倒是能改,但你得自己会写脚本,或者请其他懂的人写脚本(目测文档名上就包含了时间,所以应该不难写,只不过我不会写doge )。

    实际上文档的 ID 跟创建时间有关,改了 ID 也就改了创建的时间,可以在.sy 文件里根据文档名上的时间来批量替换文档 ID(包括这个.sy 文件的文件名,如果有子文档的话还包括同名的文件夹名称):

    image.png

    感谢大佬!不知道这个会不会影响同步或者冲突判断之类的东西?
    zxkmm
    @zxkmm 我也不知道,我只改了一个文档,感觉好像没什么问题
    JeffreyChen
    @a2930610542 感谢,我改天试验一下修改我从 joplin 导入进来的那批
    zxkmm
    @zxkmm 再提醒一下,改完 ID 要重建索引
    JeffreyChen 1
  • klwb 3

    感谢各路大神回复啊,我写了个脚本可以批量修改创建时间,如果需要可以交流使用:)

    改完要确实要重建索引:)

    ```python
    import os
    import json
    import re
    
    def process_files(directory_path):
        mapping_array = []
    
        # 遍历 SiYuan/data 目录下所有 .sy 结尾的文件
        for root, dirs, files in os.walk(directory_path):
            for file in files:
                if file.endswith(".sy"):
                    file_path = os.path.join(root, file)
              
                    # 提取文件名中的时间和唯一码
                    match = re.match(r'(\d+)-(\w+)\.sy', file)
                    if match:
                        create_time, file_key = match.groups()
                    else:
                        continue
              
                    # 读取 JSON 文件内容,根据这个title你可以确定笔记创建时间(从其他笔记应用导过来)
                    with open(file_path, 'r', encoding='utf-8') as json_file:
                        data = json.load(json_file)
                        title_content = data.get("Properties", {}).get("title", "")
    
                    # 生成映射数组
                    mapping = {
                        'key': file_key,
                        'title': title_content,
                        'real_create_time': '',
                        'filePath': file_path
                    }
    
                    mapping_array.append(mapping)
    
        # 将映射数组保存到 mappings.txt 文件中
        with open('mappings.txt', 'w', encoding='utf-8') as mappings_file:
            json.dump(mapping_array, mappings_file, ensure_ascii=False, indent=2)
    
    
    
    
    # 替换你思源本地数据绝对路径
    directory_path = '/Users/yourdir/SiyuanTestCanDelete/data'
    process_files(directory_path)
    

    根据你导入的笔记 文本编辑器打开 mappings.txt 文件手动修改,依据 20231219164139 这样的格式给 real_create_time 赋值即可

    import json
    import re
    import os
    
    def replace_time_in_files(mapping_array):
        for mapping in mapping_array:
            # 只有当 real_create_time 不为空时才执行替换操作
            if mapping['real_create_time']:
                old_file_path = mapping['filePath']
    
                # 读取旧文件内容
                with open(old_file_path, 'r', encoding='utf-8') as old_file:
                    file_content = old_file.read()
    
                    # 替换文件内容中的时间戳
                    new_file_content = re.sub(
                        r'(?<="ID":")(\d{14})|(?<="id":")(\d{14})|(?<="updated":")(\d{14})',
                        mapping['real_create_time'],
                        file_content
                    )
    
                # 构造新文件名
                old_dir, old_file_name = os.path.split(old_file_path)
                new_file_name = mapping['real_create_time']+'-'+mapping['key']+'.sy'
          
                new_file_name = os.path.join(old_dir, new_file_name)
          
                # print(old_dir,old_file_path,new_file_name,new_file_content,sep='\r\n\r\n')
          
                # 写入新文件
                with open(new_file_name, 'w', encoding='utf-8') as new_file:
                    new_file.write(new_file_content)
    
                # 删除旧文件 此处先保留以备恢复
                # os.remove(old_file_path)
    
    
    # 读取映射数组
    with open('mappings.txt', 'r', encoding='utf-8') as mappings_file:
        mappings = json.load(mappings_file)
    
    # 第三步:替换文件名和文件内容中的时间
    replace_time_in_files(mappings)
    
  • klwb

    文件 id 要改,里面内容的 id 也要改,一致的话不会有问题

    1 回复
  • 感谢大佬!请问改了以后 S3 云同步还正常吗?

    1 回复
  • klwb 1 评论

    正常的,不过搞之前建议还是导出备份一下

    快照功能很好用,不用到处备份,直接标记快照就好了
    klwb
  • duolanda 1

    非常感谢 @klwb 大佬提供的代码和思路!

    我是有大量笔记(1500+)要从印象笔记迁移过来,发现手动添加日期不现实,但是我使用的工具 evernote2md 导出的 md 文件属性里的日期本来就是正确的。于是我稍微修改了大佬的代码,添加了根据 title 寻找对应文件名 md 文件并获得日期的功能,目前来看我的笔记都成功修改为正确时间了。

    再次提醒一下各位,我的思源笔记里都是迁移过来的内容,所以执行的时候并不担心数据丢失问题,大家在使用下面代码的时候最好还是做好数据备份或者注释掉删除旧笔记的代码。

    代码字数刚好超过限制了,传到了 GitHub Gist: date_change.py

    1 回复
  • klwb

    对的,大量笔记的话就要自动化了,印象导出的文件 enex 是 xml 格式里面有所有笔记的 index,后面我也写了个方法,自动索引对应

    import xml.etree.ElementTree as ET
    
    def parse_xml_iterative(xml_file):
        notes_data = []
      
        context = ET.iterparse(xml_file, events=('start', 'end'))
        context = iter(context)
        event, root = next(context)  # 获取根节点
    
        for event, elem in context:
            if event == 'end' and elem.tag == 'note':
                title = elem.find('./title').text
                created = elem.find('./created').text
                updated = elem.find('./updated').text
    
                notes_data.append({
                    'title': title,
                    'created': created.replace('T','').replace('Z',''),
                    'updated': updated.replace('T','').replace('Z','')
                })
    
                root.clear()  # 清除已处理的元素,减少内存占用
    
        return notes_data
    
请输入回帖内容 ...

推荐标签 标签

  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 31 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 657 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 11 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖 • 4 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 2 关注
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖 • 1 关注
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    30 引用 • 123 回帖
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 733 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 78 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4600 回帖 • 701 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 668 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 97 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 2 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 1 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    55 引用 • 85 回帖 • 2 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 2 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    110 引用 • 54 回帖 • 3 关注
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 527 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 101 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 478 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1508 回帖
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    124 引用 • 580 回帖
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • 音乐

    你听到信仰的声音了么?

    60 引用 • 511 回帖
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 429 回帖 • 2 关注