Filters allow you to modify [[variables]] in [[Obsidian Web Clipper/Templates|Web Clipper templates]]. Filters are applied to variables using the syntax `{{variable|filter}}`.
- Filters work for any kind of [[Variables|variable]] including `prompt`, `meta`, `selector`, and `schema` variables.
- Filters can be chained, e.g. `{{variable|filter1|filter2}}`, and are applied in the order they are added.
## Dates
Convert and modify dates.
### `date`
Converts a date to the specified format, [see reference](https://day.js.org/docs/en/display/format).
- `{{date|date:"YYYY-MM-DD"}}` converts the current date to "YYYY-MM-DD".
- Use `date:("outputFormat", "inputFormat")` to specify the input format, e.g. `"12/01/2024"|date:("YYYY-MM-DD", "MM/DD/YYYY")` parses "12/01/2024" and returns `"2024-12-01"`.
### `date_modify`
Modifies a date by adding or subtracting a specified amount of time, [see reference](https://day.js.org/docs/en/manipulate/add).
- `"2024-12-01"|date_modify:"+1 year"` returns `"2025-12-01"`
- `"2024-12-01"|date_modify:"- 2 months"` returns `"2024-10-01"`
### `duration`
Converts ISO 8601 duration strings or seconds into formatted time strings. Uses tokens: `HH` (padded hours), `H` (hours), `mm` (padded minutes), `m` (minutes), `ss` (padded seconds), `s` (seconds).
- `"PT1H30M"|duration:"HH:mm:ss"` returns `"01:30:00"`.
- `"3665"|duration:"H:mm:ss"` returns `"1:01:05"`.
- Setting `duration` without any parameters uses `HH:mm:ss` over 1 hour, `mm:ss` under 1 hour.
- Supports both ISO 8601 duration strings (e.g., `PT6702S`, `PT1H30M`) and plain seconds.
## Text conversion and capitalization
Convert text strings from one format to another.
### `camel`
Converts text to `camelCase`.
### `capitalize`
Capitalizes the first character of the value and converts the rest to lowercase, e.g. `"hELLO wORLD"|capitalize` returns `"Hello world"`.
### `kebab`
Converts text to `kebab-case`.
### `lower`
Converts text to `lowercase`.
### `pascal`
Converts text to `PascalCase`.
### `replace`
Replaces occurrences of specified text:
- Simple replacement: `"hello!"|replace:",":""` removes all commas.
- Multiple replacements: `"hello world"|replace:("e":"a","o":"0")` returns `"hall0 w0rld"`.
- Replacements are applied in the order they are specified.
- To remove specified text, use `""` as the replacement value.
- Special characters including `: | { } ( ) ' "` should be escaped with a backslash when used in the search term, e.g. `\:` to search for a literal colon.
Regex is supported using JavaScript regex syntax:
- Replace all vowels: `"hello world"|replace:"/[aeiou]/g":"*"` → `"h*ll* w*rld".`
- Case-insensitive: `"HELLO world"|replace:"/hello/i":"hi"` → `"hi world".`
- Multiple regex: `"hello world"|replace:("/[aeiou]/g":"*","/\s+/":"-")` → `"h*ll*-w*rld"`.
- Available flags: `g` (global), `i` (case-insensitive), `m` (multiline), `s` (dotAll), `u` (unicode), `y` (sticky).
### `safe_name`
Converts text to a safe file name.
- By default, `safe_name` applies the most conservative sanitization rules.
- OS-specific rules can be applied with `safe_name:os` where `os` can be `windows`, `mac`, or `linux` to only apply the rules for that operating system.
### `snake`
Converts text to `snake_case`.
### `title`
Converts text to `Title Case`, e.g. `"hello world"|title` returns `"Hello World"`.
### `trim`
Removes white space from both ends of a string.
- `" hello world "|trim` returns `"hello world"`.
### `uncamel`
Converts camelCase or PascalCase to space-separated words, which you can further format with other filters like `title` or `capitalize`.
- `"camelCase"|uncamel` returns `"camel case"`.
- `"PascalCase"|uncamel` returns `"pascal case"`.
### `upper`
Converts a value to uppercase, e.g. `"hello world"|upper` returns `"HELLO WORLD"`.
## Text formatting
Apply [[Basic formatting syntax]] and [[Advanced formatting syntax]] to text.
### `blockquote`
Adds a Markdown quote prefix (`> `) to each line of the input.
### `callout`
Creates a [[Callouts|callout]] with optional parameters: `{{variable|callout:("type", "title", foldState)}}`
- `type` is the callout type, and defaults to "info"
- `title` is the callout title, and defaults to empty
- `foldState` is a boolean to set the fold state (true for folded, false for unfolded, null for not foldable)
### `footnote`
Converts an array or object into a list of Markdown footnotes.
- For arrays: `["first item","second item"]|footnote` returns: `[^1]: first item` etc.
- For objects: `{"First Note": "Content 1", "Second Note": "Content 2"}|footnote` returns: `[^first-note]: Content 1` etc.
### `fragment_link`
Converts strings and arrays into [text fragment](https://developer.mozilla.org/en-US/docs/Web/URI/Fragment/Text_fragments) links. Defaults to "link" for the link text.
- `highlights|fragment_link` returns `Highlight content [link](text-fragment-url)`
- `highlights|fragment_link:"custom title"` returns `Highlight content [custom title](text-fragment-url)`
### `image`
Converts strings, arrays, or objects into Markdown image syntax.
- For strings: `"image.jpg"|image:"alt text"` returns `![alt text](image.jpg)`.
- For arrays: `["image1.jpg","image2.jpg"]|image:"alt text"` returns an array of Markdown image strings with the same alt text for all images.
- For objects: `{"image1.jpg": "Alt 1", "image2.jpg": "Alt 2"}|image` returns Markdown image strings with alt text from the object keys.
### `link`
Converts strings, arrays, or objects into Markdown link syntax (not to be confused with [[Filters#`wikilink`|wikilink]]).
- For strings: `"url"|link:"author"` returns `[author](url)`.
- For arrays: `["url1","url2"]|link:"author"` returns an array of Markdown links with the same text for all links.
- For objects: `{"url1": "Author 1", "url2": "Author 2"}|link` returns Markdown links with the text that matches the object keys.
### `list`
Converts an array to a Markdown list.
- `list` to convert to a bullet list.
- `list:task` to convert to a task list.
- `list:numbered` to convert to a numbered list.
- `list:numbered-task` to convert to a task list with numbers.
### `table`
Converts an array or array of objects into a [[Advanced formatting syntax#Tables|Markdown table]]:
- For an array of objects, it uses the object keys as headers.
- For an array of arrays, it creates a table with each nested array as a row.
- For a simple array, it creates a single-column table with "Value" as the header.
### `wikilink`
Converts strings, arrays, or objects into Obsidian [[Link notes|wikilink]] syntax.
- For strings: `"page"|wikilink` returns `[[page]]`.
- For strings with alias: `"page"|wikilink:"alias"` returns `[[page|alias]]`.
- For arrays: `["page1","page2"]|wikilink` returns an array of wikilinks without aliases.
- For arrays with alias: `["page1","page2"]|wikilink:"alias"` returns an array of wikilinks with the same alias for all links.
- For objects: `{"page1": "alias1", "page2": "alias2"}|wikilink` returns wikilinks with the keys as page names and values as aliases.
## Numbers
### `calc`
Performs basic arithmetic operations on numbers.
- Supports operators: `+`, `-`, `*`, `/`, `**` (or `^`) for exponentiation.
- Example: `"5"|calc:"+10"` returns `"15"`.
- Example: `"2"|calc:"**3"` returns `"8"` (2 cubed).
- Returns the original string if the input is not a number.
### `length`
Returns the length of strings, arrays, or number of keys in objects.
- For strings: `"hello"|length` returns `"5".`
- For arrays: `["a","b","c"]|length` returns `"3".`
- For objects: `{"a":1,"b":2}|length` returns `"2"`.
### `round`
Rounds a number to the nearest integer or to a specified number of decimal places.
- Without parameters: `3.7|round` returns `4`.
- With decimal places specified: `3.14159|round:2` returns `3.14`.
## HTML processing
Process HTML content and convert HTML to Markdown. Note that your input [[Variables|variable]] must contain HTML content, e.g. using `{{fullHtml}}`, `{{contentHtml}}` or a `{{selectorHtml:}}` variable.
### `markdown`
Converts a string to an [[Obsidian Flavored Markdown]] formatted string.
- Useful when combined with variables that return HTML such as `{{contentHtml}}`, `{{fullHtml}}`, and selector variables like `{{selectorHtml:cssSelector}}`.
### `remove_attr`
Removes only the specified HTML attributes from tags.
- Example: `"<div class="test" id="example">Content</div>"|remove_attr:"class"` returns `<div id="example">Content</div>`.
- Multiple attributes: `{{contentHtml|remove_attr:("class,style,id")}}`
### `remove_html`
Removes the specified HTML elements and their content from a string.
- Supports tag name, class, or id, e.g. `{{contentHtml|remove_html:("img,.class-name,#element-id")}}`
- To remove only HTML tags or attributes without removing the content use the `strip_tags` or `strip_attr` filters.
### `remove_tags`
Removes only the specified HTML tags. Keeps the content of the tags.
- Example: `"<p>Hello <b>world</b>!</p>"|remove_tags:"b"` returns `"<p>Hello world!</p>"`.
- Multiple tags: `{{contentHtml|remove_tags:("a,em,strong")}}`
### `replace_tags`
Replaces HTML tags, maintaining the content and attributes of the tag.
- `{{contentHtml|replace_tags:"strong":"h2"}}` replaces all `<strong>` tags with `<h2>`.
### `strip_attr`
Removes **all** HTML attributes from a string.
- Use `strip_attr:("class, id")` to keep specific attributes.
- Example: `"<div class="test" id="example">Content</div>"|strip_attr:("class")` returns `<div id="example">Content</div>`.
### `strip_md`
Removes **all** Markdown formatting and returns a plain text string, e.g. turning `**text**` into `text`.
- Turns formatted text into unformatted plain text, including bold, italic, highlights, headers, code, blockquotes, tables, task lists, and wikilinks.
- Entirely removes tables, footnotes, images, and HTML elements.
### `strip_tags`
Removes **all** HTML tags from a string. Content within the tag is preserved.
- Use `strip_tags:("p,strong,em")` to keep specific tags.
- Example: `"<p>Hello <b>world</b>!</p>"|strip_tags:("b")` returns `Hello <b>world</b>!`.
## Arrays and objects
Process arrays and objects.
### `first`
Returns the first element of an array as a string.
- `["a","b","c"]|first` returns `"a"`.
- If the input is not an array, it returns the input unchanged.
### `join`
Combines elements of an array into a string.
- `["a","b","c"]|join` returns `"a,b,c"`.
- A custom separator can be specified: `["a","b","c"]|join:" "` returns `"a b c"`. Use `join:"\n"` to separate elements with a line break.
- It can be useful after `split` or `slice`: `"a,b,c,d"|split:","|slice:1,3|join:" "` returns `"b c"`.
### `last`
Returns the last element of an array as a string.
- `["a","b","c"]|last` returns `"c"`.
- If the input is not an array, it returns the input unchanged.
### `map`
Applies a transformation to each element of an array using the syntax `map:item => item.property` or `map:item => item.nested.property` for nested properties.
- `[{gem: "obsidian", color: "black"}, {gem: "amethyst", color: "purple"}]|map:item => item.gem` returns `["obsidian", "amethyst"]`.
- Use parentheses for object literals and complex expressions: `map:item => ({key: value})`, e.g.: `[{gem: "obsidian", color: "black"}, {gem: "amethyst", color: "purple"}]|map:item => ({name: item.gem, color: item.color})` returns `[{name: "obsidian", color: "black"}, {name: "amethyst", color: "purple"}]`.
String literals are supported and automatically wrapped in an object with a `str` property. The `str` property is used to store the result of string literal transformations, e.g. `["rock", "pop"]|map:item => "genres/${item}"` returns `[{str: "genres/rock"}, {str: "genres/pop"}]`.
Combine `map` with the `template` filter, e.g. `map:item => ({name: ${item.gem}, color: item.color})|template:"- ${name} is ${color}\n"`.
### `object`
Manipulates object data:
- `object:array` converts an object to an array of key-value pairs.
- `object:keys` returns an array of the object's keys.
- `object:values` returns an array of the object's values.
- Example: `{"a":1,"b":2}|object:array` returns `[["a",1],["b",2]]`.
### `slice`
Extracts a portion of a string or array.
- For strings: `"hello"|slice:1,4` returns `"ell"`.
- For arrays: `["a","b","c","d"]|slice:1,3` returns `["b","c"]`.
- If only one parameter is provided, it slices from that index to the end: `"hello"|slice:2` returns `"llo"`.
- Negative indices count from the end: `"hello"|slice:-3` returns `"llo"`.
- The second parameter is exclusive: `"hello"|slice:1,4` includes characters at indices 1, 2, and 3.
- Using a negative second parameter excludes elements from the end: `"hello"|slice:0,-2` returns `"hel"`.
### `split`
Divides a string into an array of substrings.
- `"a,b,c"|split:","` returns `["a","b","c"]`.
- `"hello world"|split:" "` returns `["hello","world"]`.
- If no separator is provided, it splits on every character: `"hello"|split` returns `["h","e","l","l","o"]`.
- Regular expressions can be used as separators: `"a1b2c3"|split:[0-9]` returns `["a","b","c"]`.
### `template`
Applies a template string to an object or array of objects, using the syntax `object|template:"Template with ${variable}"`.
- Access nested properties: `{"gem":{"name":"Obsidian"}}|template:"${gem.name}"` returns `"Obsidian"`.
- For objects: `{"gem":"obsidian","hardness":5}|template:"${gem} has a hardness of ${hardness}"` returns `"obsidian has a hardness of 5"`.
- For arrays: `[{"gem":"obsidian","hardness":5},{"gem":"amethyst","hardness":7}]|template:"- ${gem} has a hardness of ${hardness}\n"` returns a formatted list.
Works with string literals from `map` by accessing the `str` property:
- Example: `["rock", "pop"]|map:item => "genres/${item}"|template:"${str}"` returns `"genres/rock\ngenres/pop"`.
- The `str` property is automatically used when applying `template` to objects created by `map` with string literals.
### `unique`
Removes duplicate values from arrays and objects.
- For arrays of primitives: `[1,2,2,3,3]|unique` returns `[1,2,3]`.
- For arrays of objects: `[{"a":1},{"b":2},{"a":1}]|unique` returns `[{"a":1},{"b":2}]`.
- For objects it removes properties with duplicate values, keeping the last occurrence's key.
- For strings it returns the input unchanged.