模板: 生成文件树目录

2021 年 7 月 28 日 已经解决, .actioin{define "m1"} 输错了.

模板嵌套

在尝试通过模板批量生成双链,我目前只能做到 生成一级目录和二级目录下的双链.

有没有可能通过一个模板实现生成一个文件夹下包括次级文件夹下所有文档的双链,并将对应的文件夹作为标题输出

想了想好像只能通过递归来实现,但是通过递归的话,这样子就需要用到模板的嵌套

但是我定义子模版的时候会遇到这个问题

.action{$dirPath:= "/siyuan/test/test1/test2/" }

.actioin{define "m1"}
	###### Test
.action{end}

.action{template "m1"}

image.png

模板中函数调用

浏览文档的时候,发现其中的 模板函数 似乎是需要系统中自定义的函数.

后续是否会有计划开发相关的函数,比如递归生成多级目录下的双链,以及其他功能.

2 操作
crowds21 在 2021-07-28 23:19:53 更新了该帖
crowds21 在 2021-07-26 09:30:44 更新了该帖

广告 我要投放

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • crowds21 2 评论
    订阅者 作者

    成功啦,获取当前文件夹以及子级别文件夹中所有文档的双链

    .action{$docid:=.id}
    .action{$docname:=.title}
    .action{$block := (queryBlocks "select * from blocks where type='d' and id ='?' "  $docid)}
    .action{$filePath :=" "}
    .action{$fileBox :=" "}
    .action{$lastFilePath := " "}
    .action{$dirPath := " "}
    .action{$numOfSearch := 0}
    
    .action{$regexDirPath:="(/(\\.|\\w|\\s|-|[^x00-xff])+)*/"}
    
    
    .action{/*获取文件的目录路径*/}
    	.action{range $index,$v:=$block}
    		.action{$filePath = $v.Path}
    		.action{$fileBox =  $v.Box}
    	.action{end}
    	.action{/*通过正则表达式获取该文件所在的文件夹*/}
    	.action{$dirPath =(regexFind  $regexDirPath  $filePath )}
    
    .action{/*获取目录包括子目录下所有的文件*/}
    	.action{$block := (queryBlocks "select * from blocks where path like'?%' and type='d' and box='?' order by length(path) "  $dirPath $fileBox)}
    
    
    
    .action{/*获取所有文件夹路径*/}
    .action{$filePathList:= list $dirPath}
    .action{range $index, $v:=$block}
    
    	.action{$filePath = (regexFind  $regexDirPath  $v.Path )}
    
    	.action{if not (has  $filePath $filePathList)}
    		.action{$filePathList = append  $filePathList $filePath}
    	.action{end}
    	.action{$numOfSearch = $index}
    .action{end}
    
    > 由于搜索次数的限制,共有.action{$numOfSearch}条数据输出.
    > 如果需要将搜索次数调大,使用后记得改回来哦.
    
    .action{/*输出双链*/}
    .action{range $listItem:=$filePathList}
    ###### .action{$listItem}
    	.action{range $v:=$block}
    
    	.action{$filePath = (regexFind  $regexDirPath  $v.Path )}
    
    	.action{if eq $listItem $filePath }
    - ((.action{$v.ID}))
    	.action{end}
    
    	.action{end}
    .action{end}
    
    
    1 操作
    crowds21 在 2021-07-26 09:33:36 更新了该回帖
    获取路径的部分是通过 正则来实现的, sprig 中默认有函数可以调用,应该更方便些 base "foo/bar/baz"
    crowds21
    该模板后续会放入 Organized 中
    crowds21
  • crowds21
    订阅者 作者

    记录几个想法

    统计/ 数目确定层级

    sql������ͳ��һ���ֶ���ij���ַ����ֵĸ���_�ٶ�֪��

    sql 中好像还有一个 replace 函数,可以试着计算/的数目,来判断文件夹的层级。

    但是查询结果就不是原表了,可能在 siyuan 中无法执行。

    目前的思路

    目前是在 sql 查询时,通过 path 的长度排序,思源中的 path 长度包括了文件名。

    那么通常情况下,属于子文件夹层级越多,path 越长,放入 list 的时间也就会也靠后。但是不排除就在二级文件夹,文件名却很长,比三级文件夹和文件名加起来还要长。极端情况下二级文件夹下全部的文件名都是这样的,该文件夹就会在最后被输出结果。(但是凑合着用也够了)

    查询结果的正则处理后排序

    这时候还有一种方法就是在 sql 查询的时候,就对 path 结果进行正则处理。但也回破坏原本表的结构。无法在查询过程中实现。

    普通结果的比较和排序

    那在查询结果后,去除文件名的部分,得到的就会是几组固定长度的字符串了。

    而这时候面临的还是一个比较大小和排序的问题。但是 sprig 中似乎没有获取字符串长度,或和字符串比较相关的函数。

    1 操作
    crowds21 在 2021-07-26 13:16:39 更新了该回帖
  • Clouder 1 1 评论
    订阅者

    其实可以在语句中重写 LIMIT,避免让用户去设置里手动调整。

    select * from blocks where path like'?%' and type='d' and box='?' order by length(path) LIMIT 1000
    

    经过我的测试,设置成负数似乎就不限制了。

    select * from blocks where path like'?%' and type='d' and box='?' order by length(path) LIMIT -1
    
    啊,这个太对了,我给忘了。
    crowds21