如何修改创建时间?

如题

印象和 notion 过来的报个到!

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

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

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

image.png

  • 思源笔记

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

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

    19194 引用 • 72299 回帖

相关帖子

欢迎来到这里!

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

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

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

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

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

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

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

  • muxue

    你从别的软件导出的文件里面,那个导出的文件的创建时间应该也是导出的时间吧……除非是本地的 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
    
请输入回帖内容 ...

推荐标签 标签

  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖 • 2 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 691 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    15 引用 • 7 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 453 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 179 关注
  • Quicker

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

    22 引用 • 81 回帖
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 468 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 247 回帖 • 164 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    116 引用 • 99 回帖 • 268 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 2 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • 服务器

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

    124 引用 • 580 回帖
  • CodeMirror
    1 引用 • 2 回帖 • 122 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 185 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 37 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 20 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 404 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    96 引用 • 330 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    22 引用 • 31 回帖 • 1 关注
  • 倾城之链
    23 引用 • 66 回帖 • 110 关注
  • 单点登录

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

    9 引用 • 25 回帖 • 1 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3169 引用 • 8207 回帖 • 1 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    77 引用 • 1739 回帖
  • 招聘

    哪里都缺人,哪里都不缺人。

    189 引用 • 1056 回帖 • 2 关注
  • abitmean

    有点意思就行了

    24 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 319 关注