模板: 时长统计

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

我一直都想把《自控力》里读到的一些东西和思源相结合.但一直没有头绪,最近对模板更熟悉一些了,所以实现了一个挺有意思的功能, 输出你在这个文档中编辑的时长,和中断编辑的时间.

主要思路是,获取今天 0 点的字符串,通过 SQL 获取大于该串的 Block,并按照从小到大排序.

依次,两者之间相减,如果时间小于 15min 进行下一次循环.

如果两者之间的间隔大于 15min,则视为,我分心了,去玩手机或者倒腾其他有意思的东西去了. 然后计算出今天的第一次编辑上一次编辑之间的时间间隔.

然后再将这一次编辑的时间,记录为 thisBlock (第一次编辑) 重复上述两两相减的过程.

最后将每一次时间段相加,得到一个总的时长.结果难免会有一点误差,但对于复盘是绰绰有余的.

效果(开小差现场)

下图是调整过 CSS 之后的效果 , 模板生成的是一个带有属性的超级块, 因此调整 CSS 还算是方便.

image.png

Templates
.action{/*获取文档的基本信息*/}
.action{$docID:=.id}
.action{$docTitle := .title}
.action{$docBox :=" "}
.action{$docPath := " "}
.action{$docCreated := " "}
.action{$docUpdated := " "}
.action{$getDocInfo := (queryBlocks "SELECT * FROM blocks WHERE id='?' and type='d' " $docID )}
.action{range $v:= $getDocInfo}
	.action{$docBox =$v.Box}
	.action{$docPath = $v.Path}
	.action{$docCreated = toDate "20060102150405" $v.Created | date "2006-01-02"}
	.action{$docUpdated = $v.Updated}
.action{end}

.action{/*获取今天的开始时间*/}
.action{$today:=now|date "20060102"}
.action{$today = cat $today "000000"}
.action{$today = nospace $today}
.action{/*定义变量*/}
.action{$firstBlock := " "}
.action{$thisBlock := " "}
.action{$lastBlock := " "}
.action{$duration:= 0.0}
.action{$workHours:= 0.0}
.action{$flag := 0}

.action{/*获取中断时间和总时长*/}
{{{row
.action{$recent_block := (queryBlocks "SELECT * FROM blocks WHERE root_id = '?'  and updated >'?' order by updated limit -1 " $docID $today)}
.action{range $index,$v:=$recent_block}
	.action{$thisBlock = $v.Updated}
	.action{/*获取今天第一个创建的块*/}
	.action{if eq $index 0}
		.action{$firstBlock = $v.Updated }
		.action{$lastBlock = $firstBlock}
	.action{else}
		.action{$duration:= ((toDate "20060102150405" $thisBlock).Sub  (toDate "20060102150405" $lastBlock)).Minutes }
		.action{if gt $duration 15.0 }
		.action{$flag = 1}
@Interrupted .action{toDate "20060102150405" $firstBlock | date "15:04"} - .action{toDate "20060102150405" $lastBlock | date "15:04"}
			.action{$workHours = addf $workHours ((toDate "20060102150405" $lastBlock).Sub  (toDate "20060102150405" $firstBlock)).Minutes }
			.action{$firstBlock = $thisBlock}
		.action{end}
	.action{end}
	.action{$lastBlock = $thisBlock}
.action{end}

.action{/*如果中途有被打断,输出最后一段时间*/}
.action{if eq $flag 1}
	@Interrupted .action{toDate "20060102150405" $firstBlock | date "15:04"} - .action{toDate "20060102150405" $lastBlock | date "15:04"}
.action{end}
.action{$workHours = addf $workHours ((toDate "20060102150405" $lastBlock).Sub  (toDate "20060102150405" $firstBlock)).Minutes }

.action{$workHours = (divf ($workHours|int64) 60)| toString }
.action{$workHours = regexFind "\\w*\\.\\w\\w" $workHours}
@Duration .action{now|date "2006-01-02 15:04:05"} | .action{$workHours}h
}}}
{: name="@DocInfo" alias="@Duration" }

  • 思源笔记

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

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

    18591 引用 • 69190 回帖 • 1 关注
1 操作
crowds21 在 2021-08-07 22:10:11 更新了该帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 自控力正在看第二遍。。。

    番茄 todo 之类的应该更适合吧。。。

    2 回复
  • 其他回帖
  • crowds21

    自控力中强调的一个基础是,你需要训练自己的自控力. 意识到自己在做决定,意识到自己分心了.

    焦点是自我觉察,所以这个模板的意义是对于刚开始意识不到自己分心,导致多次中断的时候,能够在最后做出一个统计,让自己意识到自己其实只专注了多久.

    每个人时间管理的方式不一样.对于一些事情,我个人不喜欢番茄的方式. TODO 也只不过是一个待办清单,和训练注意力没有啥关系.

  • crowds21

    我暂时的计划是将前几章的章节训练,适当的和思源结合做成一些模板,这样子之后对那些开始阅读这本书的人,提供了一个很好的训练机会.我周围一些朋友读完这本书,并没有尝试去做里面讲到的一些"练习".蛮可惜的.

    当然这个过程会比较久,我也需要重头再去一步步做一下,看看有没有什么不影响正常记笔记的方式. 如果真的整合成一个套的话,我就肯定不会发帖子了,直接发集市了.

crowds21
不带评论的观察是人类智力的最高形式 上海

推荐标签 标签

  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 522 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    330 引用 • 614 回帖 • 1 关注
  • OnlyOffice
    4 引用 • 27 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 44 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    675 引用 • 535 回帖
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    161 引用 • 473 回帖
  • 笔记

    好记性不如烂笔头。

    303 引用 • 777 回帖
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 619 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 24 关注
  • Markdown

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

    163 引用 • 1450 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    126 引用 • 1699 回帖
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 5 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    1 引用 • 11 回帖 • 1 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 592 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 552 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 44 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 298 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • 996
    13 引用 • 200 回帖 • 1 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 25 关注
  • 酷鸟浏览器

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

    3 引用 • 59 回帖 • 22 关注
  • 思源笔记

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

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

    18591 引用 • 69190 回帖 • 1 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    710 引用 • 1173 回帖 • 176 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖