Structure of a Query
<QUERY-TYPE> <fields> |
Query-Type fields
Query-Type 包括:
- LIST 单个列(列即field)
- TABLE 多个列
- TASK 类似list单列查询
- CALENDAR A calendar view displaying each hit
fields 类似 SQL的查询列(Column),常用的fields:
- file.xx
- …
file支持的属性: https://blacksmithgu.github.io/obsidian-dataview/annotation/metadata-pages/
- file.name
- file.mtime
- file.tasks
- file.lists
- …
file还包括两个特殊的属性, list 和 task,这里指的是文件内容里使用 gfm 的 list & todo语法格式的行,而不是“QUERY-TYPE”的 LIST 和 TASK
file支持的子属性 :
- file.lists.text
- file.tasks.text
- 但是似乎没有 file.line 这种,无法查询line,只能查询list、task行里的内容
例1:// 原文 * this's list1 [status:: todo]
// 查询全部的list中包含'status:: todo'的行
TABLE L.text AS "My lists"
FLATTEN file.lists AS L
WHERE contains(L.status, "todo")
例2:ist lines tagged with #exam in my folder “3_semester”,TABLE WITHOUT ID string(link(rows.file.link, rows.title)[0]) AS class, regexreplace(list(rows.L.text), "#exam", "") AS "exam"
FROM "3_semester"
FLATTEN file.lists AS L
WHERE contains(L.tags, "#exam")
GROUP BY file.link
https://www.reddit.com/r/ObsidianMD/comments/17s0oiu/dataview_list_of_lines_with_tag/
file.list 和 task 还支持更多的查询属性 : 如 status、checked、text.. Metadata on Tasks and Lists - Dataview
FROM source
FROM后可以是 文件夹 or Tag,
例子-Combining sources:
LIST |
DATA-COMMAND
Data Commands - Dataview
包括 FROM、WHERE、SORT、GROUP BY、FLATTEN
FROM
- Tags: To select from a tag (and all its subtags), use
FROM #tag
. - Folders: To select from a folder (and all its subfolders), use
FROM "folder"
. - Single Files: To select from a single file, use
FROM "path/to/file"
. - Also “negate” sources:
FROME -#tag AND -"folder"
WHERE
LIST WHERE file.mtime >= date(today) - dur(1 day) |
LIST FROM #projects |
FLATTEN
Flatten an array in every row, yielding one result row per entry in the array.
自定义metadata
https://blacksmithgu.github.io/obsidian-dataview/annotation/add-metadata/
自定义mate支持两种方式:
- Frontmatter 里定义kv对
- Inline 的方式定义kv对
举例1:原文 TODO:: 买机票
定义了kv对,key即‘TODO’,val即‘买机票’,如果要查询出全部的TODO,语句如下:
TABLE TODO |
举例2:原文如下I would rate this a [rating:: 9]! It was [mood:: acceptable].
- [ ] Send an mail to David about the deadline [due:: 2022-04-05].
查询:task from #projects/active
sort rating desc
where mood = "acceptable"
对task的支持
参考: Metadata on Tasks and Lists - Dataview
dataview 支持一些预定的 metadata,例如 start、due、completion
例子1,@ref:: https://forum.obsidian.md/t/create-dataview-table-of-multiple-tasks-within-notes/31054
TABLE WITHOUT ID |
例子2TABLE WITHOUT ID
regexreplace(Tasks.text, "\[.*$", "") AS Task,
Tasks.due AS "Due Date",
Tasks.link AS "File"
FROM "@Project/active" FLATTEN file.tasks AS Tasks
WHERE !Tasks.completed
API & 高级用法(dataviewjs)
例1:dv.taskList(dv.pages("#idea").file.tasks
.where( t=> t.text.includes("#idea"))
.where( t=> !t.completed))
例2:let pages = dv.pages("#标签1 and -#标签2")
dv.table(
[name, genre],
pages.sort(b => file.mtime, "desc").map(b => [b.file.link, b.genre])
)
注:需要代码块标注 dataviewjs
dataviewjs 语法参考:
最佳实践:笔记中使用 Dataview Friendly 的标识
方案1,使用自定义meta kv:
@todo1:: 这是一个todo |
方案2,使用2级标签:
#inbox/todo |