jpskill.com
🛠️ 開発・MCP コミュニティ 🔴 エンジニア向け 👤 エンジニア・AI開発者

🛠️ Obsidian Bases

obsidian-bases

Obsidianで、データベースのように情報を整理できる「

⏱ 障害ポストモーテム 1日 → 1時間

📺 まず動画で見る(YouTube)

▶ 【衝撃】最強のAIエージェント「Claude Code」の最新機能・使い方・プログラミングをAIで効率化する超実践術を解説! ↗

※ jpskill.com 編集部が参考用に選んだ動画です。動画の内容と Skill の挙動は厳密には一致しないことがあります。

📜 元の英語説明(参考)

Create and edit Obsidian Bases (.base files) with views, filters, formulas, and summaries. Use when working with .base files, creating database-like views of notes, or when the user mentions Bases, table views, card views, filters, or formulas in Obsidian.

🇯🇵 日本人クリエイター向け解説

一言でいうと

Obsidianで、データベースのように情報を整理できる「

※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o obsidian-bases.zip https://jpskill.com/download/3224.zip && unzip -o obsidian-bases.zip && rm obsidian-bases.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/3224.zip -OutFile "$d\obsidian-bases.zip"; Expand-Archive "$d\obsidian-bases.zip" -DestinationPath $d -Force; ri "$d\obsidian-bases.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して obsidian-bases.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → obsidian-bases フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-17
取得日時
2026-05-17
同梱ファイル
2

💬 こう話しかけるだけ — サンプルプロンプト

  • Obsidian Bases を使って、最小構成のサンプルコードを示して
  • Obsidian Bases の主な使い方と注意点を教えて
  • Obsidian Bases を既存プロジェクトに組み込む方法を教えて

これをClaude Code に貼るだけで、このSkillが自動発動します。

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

Obsidian Bases スキル

使用場面

  • Obsidian で .base ファイルを作成または編集する際に使用します。
  • フィルター、数式、要約、またはカード/テーブルを使用して、データベースのようなノートビューを表示する際に使用します。
  • ユーザーが Obsidian Bases について具体的に質問した際に使用します。

ワークフロー

  1. ファイルの作成: 有効な YAML コンテンツを含む .base ファイルを vault 内に作成します。
  2. スコープの定義: どのノートを表示するかを選択するために filters を追加します(タグ、フォルダー、プロパティ、または日付で)。
  3. 数式の追加 (オプション): formulas セクションで計算プロパティを定義します。
  4. ビューの構成: 1つ以上のビュー(tablecardslist、または map)を、表示するプロパティを指定する order とともに追加します。
  5. 検証: ファイルが有効な YAML であり、構文エラーがないことを確認します。参照されているすべてのプロパティと数式が存在することを確認します。よくある問題として、特殊な YAML 文字を含む引用符なしの文字列、数式表現内の引用符の不一致、formulasX を定義せずに formula.X を参照するケースがあります。
  6. Obsidian でテスト: Obsidian で .base ファイルを開き、ビューが正しくレンダリングされることを確認します。YAML エラーが表示される場合は、以下の引用符のルールを確認してください。

スキーマ

Base ファイルは .base 拡張子を使用し、有効な YAML を含みます。

# グローバルフィルターはベース内のすべてのビューに適用されます
filters:
  # 単一のフィルター文字列にできます
  # または and/or/not を持つ再帰的なフィルターオブジェクトにできます
  and: []
  or: []
  not: []

# すべてのビューで使用できる数式プロパティを定義します
formulas:
  formula_name: 'expression'

# プロパティの表示名と設定を構成します
properties:
  property_name:
    displayName: "Display Name"
  formula.formula_name:
    displayName: "Formula Display Name"
  file.ext:
    displayName: "Extension"

# カスタム要約数式を定義します
summaries:
  custom_summary_name: 'values.mean().round(3)'

# 1つ以上のビューを定義します
views:
  - type: table | cards | list | map
    name: "View Name"
    limit: 10                    # オプション: 結果を制限します
    groupBy:                     # オプション: 結果をグループ化します
      property: property_name
      direction: ASC | DESC
    filters:                     # ビュー固有のフィルター
      and: []
    order:                       # 表示するプロパティの順序
      - file.name
      - property_name
      - formula.formula_name
    summaries:                   # プロパティを要約数式にマッピングします
      property_name: Average

フィルター構文

フィルターは結果を絞り込みます。グローバルまたはビューごとに適用できます。

フィルター構造

# 単一フィルター
filters: 'status == "done"'

# AND - すべての条件が真である必要があります
filters:
  and:
    - 'status == "done"'
    - 'priority > 3'

# OR - いずれかの条件が真であればよい
filters:
  or:
    - 'file.hasTag("book")'
    - 'file.hasTag("article")'

# NOT - 一致する項目を除外します
filters:
  not:
    - 'file.hasTag("archived")'

# ネストされたフィルター
filters:
  or:
    - file.hasTag("tag")
    - and:
        - file.hasTag("book")
        - file.hasLink("Textbook")
    - not:
        - file.hasTag("book")
        - file.inFolder("Required Reading")

フィルター演算子

演算子 説明
== 等しい
!= 等しくない
> より大きい
< より小さい
>= 以上
<= 以下
&& 論理積 (AND)
\|\| 論理和 (OR)
<code>!</code> 論理否定 (NOT)

プロパティ

3種類のプロパティ

  1. ノートプロパティ - フロントマターから: note.author または単に author
  2. ファイルプロパティ - ファイルメタデータ: file.namefile.mtime など
  3. 数式プロパティ - 計算された値: formula.my_formula

ファイルプロパティ参照

プロパティ 説明
file.name String ファイル名
file.basename String 拡張子なしのファイル名
file.path String ファイルへのフルパス
file.folder String 親フォルダーのパス
file.ext String ファイル拡張子
file.size Number ファイルサイズ(バイト単位)
file.ctime Date 作成時刻
file.mtime Date 変更時刻
file.tags List ファイル内のすべてのタグ
file.links List ファイル内の内部リンク
file.backlinks List このファイルにリンクしているファイル
file.embeds List ノート内の埋め込み
file.properties Object すべてのフロントマタープロパティ

this キーワード

  • メインコンテンツエリア内: ベースファイル自体を参照します。
  • 埋め込まれている場合: 埋め込みファイルを参照します。
  • サイドバー内: メインコンテンツのアクティブなファイルを参照します。

数式構文

数式はプロパティから値を計算します。formulas セクションで定義されます。

formulas:
  # 単純な算術
  total: "price * quantity"

  # 条件ロジック
  status_icon: 'if(done, "✅", "⏳")'

  # 文字列フォーマット
  formatted_price: 'if(price, price.toFixed(2) + " dollars")'

  # 日付フォーマット
  created: 'file.ctime.format("YYYY-MM-DD")'

  # 作成からの日数を計算します(Duration には .days を使用します)
  days_old: '(now() - file.ctime).days'

  # 期限までの日数を計算します
  days_until_due: 'if(due_date, (date(due_date) - today()).days, "")'

主要な関数

最もよく使用される関数です。すべての型(Date、String、Number、List、File、Link、Object、RegExp)の完全なリファレンスについては、FUNCTIONS_REFERENCE.md を参照してください。

関数 シグネチャ 説明
date() date(string): date 文字列を日付に解析します(YYYY-MM-DD HH:mm:ss
now() now(): date 現在の日付と時刻
today() today(): date 現在の日付(時刻 = 00:00:00)
if() if(condition, trueResult, falseResult?) 条件式
duration() duration(string): duration 期間文字列を解析します
file() file(path): file ファイルオブジェクトを取得します
link() link(path, display?): Link リンクを作成します

Duration 型

2つの日付を減算すると、結果は Duration 型になります(数値ではありません)。

Duration フィールド: duration.daysduration.hoursduration.minutesduration.seconds

📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Obsidian Bases Skill

When to Use

  • Use when creating or editing .base files in Obsidian.
  • Use for database-like note views with filters, formulas, summaries, or cards/tables.
  • Use when the user asks about Obsidian Bases specifically.

Workflow

  1. Create the file: Create a .base file in the vault with valid YAML content
  2. Define scope: Add filters to select which notes appear (by tag, folder, property, or date)
  3. Add formulas (optional): Define computed properties in the formulas section
  4. Configure views: Add one or more views (table, cards, list, or map) with order specifying which properties to display
  5. Validate: Verify the file is valid YAML with no syntax errors. Check that all referenced properties and formulas exist. Common issues: unquoted strings containing special YAML characters, mismatched quotes in formula expressions, referencing formula.X without defining X in formulas
  6. Test in Obsidian: Open the .base file in Obsidian to confirm the view renders correctly. If it shows a YAML error, check quoting rules below

Schema

Base files use the .base extension and contain valid YAML.

# Global filters apply to ALL views in the base
filters:
  # Can be a single filter string
  # OR a recursive filter object with and/or/not
  and: []
  or: []
  not: []

# Define formula properties that can be used across all views
formulas:
  formula_name: 'expression'

# Configure display names and settings for properties
properties:
  property_name:
    displayName: "Display Name"
  formula.formula_name:
    displayName: "Formula Display Name"
  file.ext:
    displayName: "Extension"

# Define custom summary formulas
summaries:
  custom_summary_name: 'values.mean().round(3)'

# Define one or more views
views:
  - type: table | cards | list | map
    name: "View Name"
    limit: 10                    # Optional: limit results
    groupBy:                     # Optional: group results
      property: property_name
      direction: ASC | DESC
    filters:                     # View-specific filters
      and: []
    order:                       # Properties to display in order
      - file.name
      - property_name
      - formula.formula_name
    summaries:                   # Map properties to summary formulas
      property_name: Average

Filter Syntax

Filters narrow down results. They can be applied globally or per-view.

Filter Structure

# Single filter
filters: 'status == "done"'

# AND - all conditions must be true
filters:
  and:
    - 'status == "done"'
    - 'priority > 3'

# OR - any condition can be true
filters:
  or:
    - 'file.hasTag("book")'
    - 'file.hasTag("article")'

# NOT - exclude matching items
filters:
  not:
    - 'file.hasTag("archived")'

# Nested filters
filters:
  or:
    - file.hasTag("tag")
    - and:
        - file.hasTag("book")
        - file.hasLink("Textbook")
    - not:
        - file.hasTag("book")
        - file.inFolder("Required Reading")

Filter Operators

Operator Description
== equals
!= not equal
> greater than
< less than
>= greater than or equal
<= less than or equal
&& logical and
\|\| logical or
<code>!</code> logical not

Properties

Three Types of Properties

  1. Note properties - From frontmatter: note.author or just author
  2. File properties - File metadata: file.name, file.mtime, etc.
  3. Formula properties - Computed values: formula.my_formula

File Properties Reference

Property Type Description
file.name String File name
file.basename String File name without extension
file.path String Full path to file
file.folder String Parent folder path
file.ext String File extension
file.size Number File size in bytes
file.ctime Date Created time
file.mtime Date Modified time
file.tags List All tags in file
file.links List Internal links in file
file.backlinks List Files linking to this file
file.embeds List Embeds in the note
file.properties Object All frontmatter properties

The this Keyword

  • In main content area: refers to the base file itself
  • When embedded: refers to the embedding file
  • In sidebar: refers to the active file in main content

Formula Syntax

Formulas compute values from properties. Defined in the formulas section.

formulas:
  # Simple arithmetic
  total: "price * quantity"

  # Conditional logic
  status_icon: 'if(done, "✅", "⏳")'

  # String formatting
  formatted_price: 'if(price, price.toFixed(2) + " dollars")'

  # Date formatting
  created: 'file.ctime.format("YYYY-MM-DD")'

  # Calculate days since created (use .days for Duration)
  days_old: '(now() - file.ctime).days'

  # Calculate days until due date
  days_until_due: 'if(due_date, (date(due_date) - today()).days, "")'

Key Functions

Most commonly used functions. For the complete reference of all types (Date, String, Number, List, File, Link, Object, RegExp), see FUNCTIONS_REFERENCE.md.

Function Signature Description
date() date(string): date Parse string to date (YYYY-MM-DD HH:mm:ss)
now() now(): date Current date and time
today() today(): date Current date (time = 00:00:00)
if() if(condition, trueResult, falseResult?) Conditional
duration() duration(string): duration Parse duration string
file() file(path): file Get file object
link() link(path, display?): Link Create a link

Duration Type

When subtracting two dates, the result is a Duration type (not a number).

Duration Fields: duration.days, duration.hours, duration.minutes, duration.seconds, duration.milliseconds

IMPORTANT: Duration does NOT support .round(), .floor(), .ceil() directly. Access a numeric field first (like .days), then apply number functions.

# CORRECT: Calculate days between dates
"(date(due_date) - today()).days"                    # Returns number of days
"(now() - file.ctime).days"                          # Days since created
"(date(due_date) - today()).days.round(0)"           # Rounded days

# WRONG - will cause error:
# "((date(due) - today()) / 86400000).round(0)"      # Duration doesn't support division then round

Date Arithmetic

# Duration units: y/year/years, M/month/months, d/day/days,
#                 w/week/weeks, h/hour/hours, m/minute/minutes, s/second/seconds
"now() + \"1 day\""       # Tomorrow
"today() + \"7d\""        # A week from today
"now() - file.ctime"      # Returns Duration
"(now() - file.ctime).days"  # Get days as number

View Types

Table View

views:
  - type: table
    name: "My Table"
    order:
      - file.name
      - status
      - due_date
    summaries:
      price: Sum
      count: Average

Cards View

views:
  - type: cards
    name: "Gallery"
    order:
      - file.name
      - cover_image
      - description

List View

views:
  - type: list
    name: "Simple List"
    order:
      - file.name
      - status

Map View

Requires latitude/longitude properties and the Maps community plugin.

views:
  - type: map
    name: "Locations"
    # Map-specific settings for lat/lng properties

Default Summary Formulas

Name Input Type Description
Average Number Mathematical mean
Min Number Smallest number
Max Number Largest number
Sum Number Sum of all numbers
Range Number Max - Min
Median Number Mathematical median
Stddev Number Standard deviation
Earliest Date Earliest date
Latest Date Latest date
Range Date Latest - Earliest
Checked Boolean Count of true values
Unchecked Boolean Count of false values
Empty Any Count of empty values
Filled Any Count of non-empty values
Unique Any Count of unique values

Complete Examples

Task Tracker Base

filters:
  and:
    - file.hasTag("task")
    - 'file.ext == "md"'

formulas:
  days_until_due: 'if(due, (date(due) - today()).days, "")'
  is_overdue: 'if(due, date(due) < today() && status != "done", false)'
  priority_label: 'if(priority == 1, "🔴 High", if(priority == 2, "🟡 Medium", "🟢 Low"))'

properties:
  status:
    displayName: Status
  formula.days_until_due:
    displayName: "Days Until Due"
  formula.priority_label:
    displayName: Priority

views:
  - type: table
    name: "Active Tasks"
    filters:
      and:
        - 'status != "done"'
    order:
      - file.name
      - status
      - formula.priority_label
      - due
      - formula.days_until_due
    groupBy:
      property: status
      direction: ASC
    summaries:
      formula.days_until_due: Average

  - type: table
    name: "Completed"
    filters:
      and:
        - 'status == "done"'
    order:
      - file.name
      - completed_date

Reading List Base

filters:
  or:
    - file.hasTag("book")
    - file.hasTag("article")

formulas:
  reading_time: 'if(pages, (pages * 2).toString() + " min", "")'
  status_icon: 'if(status == "reading", "📖", if(status == "done", "✅", "📚"))'
  year_read: 'if(finished_date, date(finished_date).year, "")'

properties:
  author:
    displayName: Author
  formula.status_icon:
    displayName: ""
  formula.reading_time:
    displayName: "Est. Time"

views:
  - type: cards
    name: "Library"
    order:
      - cover
      - file.name
      - author
      - formula.status_icon
    filters:
      not:
        - 'status == "dropped"'

  - type: table
    name: "Reading List"
    filters:
      and:
        - 'status == "to-read"'
    order:
      - file.name
      - author
      - pages
      - formula.reading_time

Daily Notes Index

filters:
  and:
    - file.inFolder("Daily Notes")
    - '/^\d{4}-\d{2}-\d{2}$/.matches(file.basename)'

formulas:
  word_estimate: '(file.size / 5).round(0)'
  day_of_week: 'date(file.basename).format("dddd")'

properties:
  formula.day_of_week:
    displayName: "Day"
  formula.word_estimate:
    displayName: "~Words"

views:
  - type: table
    name: "Recent Notes"
    limit: 30
    order:
      - file.name
      - formula.day_of_week
      - formula.word_estimate
      - file.mtime

Embedding Bases

Embed in Markdown files:

![[MyBase.base]]

<!-- Specific view -->
![[MyBase.base#View Name]]

YAML Quoting Rules

  • Use single quotes for formulas containing double quotes: 'if(done, "Yes", "No")'
  • Use double quotes for simple strings: "My View Name"
  • Escape nested quotes properly in complex expressions

Troubleshooting

YAML Syntax Errors

Unquoted special characters: Strings containing :, {, }, [, ], ,, &, *, #, ?, |, -, <, >, =, !, %, @, ` must be quoted.

# WRONG - colon in unquoted string
displayName: Status: Active

# CORRECT
displayName: "Status: Active"

Mismatched quotes in formulas: When a formula contains double quotes, wrap the entire formula in single quotes.

# WRONG - double quotes inside double quotes
formulas:
  label: "if(done, "Yes", "No")"

# CORRECT - single quotes wrapping double quotes
formulas:
  label: 'if(done, "Yes", "No")'

Common Formula Errors

Duration math without field access: Subtracting dates returns a Duration, not a number. Always access .days, .hours, etc.

# WRONG - Duration is not a number
"(now() - file.ctime).round(0)"

# CORRECT - access .days first, then round
"(now() - file.ctime).days.round(0)"

Missing null checks: Properties may not exist on all notes. Use if() to guard.

# WRONG - crashes if due_date is empty
"(date(due_date) - today()).days"

# CORRECT - guard with if()
'if(due_date, (date(due_date) - today()).days, "")'

Referencing undefined formulas: Ensure every formula.X in order or properties has a matching entry in formulas.

# This will fail silently if 'total' is not defined in formulas
order:
  - formula.total

# Fix: define it
formulas:
  total: "price * quantity"

References

Limitations

  • Use this skill only when the task clearly matches the scope described above.
  • Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
  • Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.

同梱ファイル

※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。