dataviewjs-查关键字所在行内容
...大约 4 分钟
说明:
实现通过 dataviewjs 查关键字所在行的数据
使用方法:
- 复制以下代码,在任意md文件中插入即可。
- 注意修改文件路径为自己库中的路径,否则会报错
添加dataviewjs查询的方法
- 用代码块包裹查询代码(第一行注明语言
dataviewjs
和最后一行对应结尾) - 任意位置插入即可,注意修改文件路径和查询条件
代码
代码框右下有复制按钮,点击自动复制代码
提示
此代码来源于网络,群友@小汤园壹號
推荐,代码我重新注解了一下,可能更容易看清楚。
2023-02-04:
- 新增了查询指定文件夹下的文件
- 新增了查询指定文件
```dataviewjs
// 整个代码是为了获取所有的md文件、指定文件夹、指定文件,然后过滤掉没有“#软件”的行,然后将文件名和行显示在表中。
// 参考用//注释开关指定查询范围
//获取库中的所有md文件
//const files = app.vault.getMarkdownFiles()
// 获取指定文件夹中的所有md文件,支持二级目录“080 Template/Cangshu”
//const files = app.vault.getMarkdownFiles().filter(file => file.path.includes("080 Template"))
// 获取指定 名称的 md文件中的所有行
const files = app.vault.getMarkdownFiles().filter(file => file.name.includes("Cangshu.md"))
//创建一个包含文件名和包含所需标记的行的数组
let arr = files.map(async(file) => {
// 读取文件并将内容作为字符串获取
const content = await app.vault.cachedRead(file)
//将所有内容转换为行的数组,并过滤掉包含标记“#zk”的行
let lines = await content.split("\n").filter(line => line.includes("#软件"))
// 删除行中的标记和前置空格,以便于在表中显示。其中“-”是为了删除行中的“-”,“#软件”是为了删除行中的“#软件”,“ ”是为了删除行中的空格,
for(var i=0; i < lines.length; i++) {
lines[i] = lines[i].replace(/- /g, '');
lines[i] = lines[i].replace(/ /g, '');
lines[i] = lines[i].replace("#zk", '');
}
//删除空行
console.log(lines)
// 返回包含标记的行的文件名和行的数组
return ["[["+file.name.split(".")[0]+"]]", lines]
})
//解析promises并构建表
Promise.all(arr).then(values => {
console.log(values)
// 过滤掉没有“#软件”的行,并且过滤掉zk log和timeline log ,因为zk log和timeline log是我自己的文件,不需要显示在表中,所以我过滤掉了,如果你不需要过滤掉zk log和timeline log,可以删除这两行代码
const exists = values.filter(value => value[1][0] && value[0] != "[[ZK Log]]" && value[0] != "[[+ Timeline Log]]")
//构建表,显示文件名和行
dv.table(["File", "Lines"], exists)
})
```
下面重新着色一次,就不用 dataviewjs 标签包裹了
// 整个代码是为了获取所有的md文件、指定文件夹、指定文件,然后过滤掉没有“#软件”的行,然后将文件名和行显示在表中。
// 参考用//注释开关指定查询范围
//获取库中的所有md文件
//const files = app.vault.getMarkdownFiles()
// 获取指定文件夹中的所有md文件,支持二级目录“080 Template/Cangshu”
//const files = app.vault.getMarkdownFiles().filter(file => file.path.includes("080 Template"))
// 获取指定 名称的 md文件中的所有行
const files = app.vault.getMarkdownFiles().filter(file => file.name.includes("Cangshu.md"))
//创建一个包含文件名和包含所需标记的行的数组
let arr = files.map(async(file) => {
// 读取文件并将内容作为字符串获取
const content = await app.vault.cachedRead(file)
//将所有内容转换为行的数组,并过滤掉包含标记“#zk”的行
let lines = await content.split("\n").filter(line => line.includes("#软件"))
// 删除行中的标记和前置空格,以便于在表中显示。其中“-”是为了删除行中的“-”,“#软件”是为了删除行中的“#软件”,“ ”是为了删除行中的空格,
for(var i=0; i < lines.length; i++) {
lines[i] = lines[i].replace(/- /g, '');
lines[i] = lines[i].replace(/ /g, '');
lines[i] = lines[i].replace("#zk", '');
}
//删除空行
console.log(lines)
// 返回包含标记的行的文件名和行的数组
return ["[["+file.name.split(".")[0]+"]]", lines]
})
//解析promises并构建表
Promise.all(arr).then(values => {
console.log(values)
// 过滤掉没有“#软件”的行,并且过滤掉zk log和timeline log ,因为zk log和timeline log是我自己的文件,不需要显示在表中,所以我过滤掉了,如果你不需要过滤掉zk log和timeline log,可以删除这两行代码
const exists = values.filter(value => value[1][0] && value[0] != "[[ZK Log]]" && value[0] != "[[+ Timeline Log]]")
//构建表,显示文件名和行
dv.table(["File", "Lines"], exists)
})
加群交流
如果在使用和学习中有不明白的地方,或者想看看别人的经验
- 可以查看进阶用法
- 可以加群和大家聊聊,加微信
coffeebean1688
翻滚的咖啡豆子,然后进群 - 可以查看咖啡豆豆龙_哔哩哔哩) 视频教程。😜关注、👍点赞、📀投币一键三连
- 关注公众号(文章很多):`蹦跶的咖啡豆
- 示例库(筹备中)
- 网站启用新域名:https://obsidian.vip 给VIP的你,很好记
Powered by Waline v2.15.4