typesense
Typesense is an open-source, typo-tolerant search engine optimized for instant search experiences. Learn to deploy with Docker, define collections, index documents, and build search UIs as a modern alternative to Algolia.
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o typesense.zip https://jpskill.com/download/15507.zip && unzip -o typesense.zip && rm typesense.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/15507.zip -OutFile "$d\typesense.zip"; Expand-Archive "$d\typesense.zip" -DestinationPath $d -Force; ri "$d\typesense.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
typesense.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
typesenseフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Claude が読む原文 SKILL.md(中身を展開)
この本文は AI(Claude)が読むための原文(英語または中国語)です。日本語訳は順次追加中。
Typesense
Typesense is a fast, typo-tolerant search engine you can self-host. It offers sub-50ms search, built-in typo correction, faceting, filtering, and geo-search.
Installation
# Docker deployment
docker run -d --name typesense -p 8108:8108 \
-v typesense-data:/data \
typesense/typesense:27.1 \
--data-dir /data \
--api-key=xyz123 \
--enable-cors
# Node.js client
npm install typesense
# Python client
pip install typesense
Create a Collection
// create-collection.js: Define a collection schema
const Typesense = require('typesense');
const client = new Typesense.Client({
nodes: [{ host: 'localhost', port: 8108, protocol: 'http' }],
apiKey: 'xyz123',
connectionTimeoutSeconds: 5,
});
async function createCollection() {
await client.collections().create({
name: 'products',
fields: [
{ name: 'name', type: 'string' },
{ name: 'description', type: 'string' },
{ name: 'price', type: 'float', facet: true },
{ name: 'category', type: 'string', facet: true },
{ name: 'rating', type: 'float', facet: true },
{ name: 'in_stock', type: 'bool', facet: true },
{ name: 'tags', type: 'string[]', facet: true },
],
default_sorting_field: 'rating',
});
}
createCollection().catch(console.error);
Index Documents
// index-documents.js: Import documents into Typesense
const documents = [
{ id: '1', name: 'MacBook Pro', description: 'Apple laptop with M3 chip', price: 1999, category: 'Laptops', rating: 4.8, in_stock: true, tags: ['apple', 'laptop'] },
{ id: '2', name: 'ThinkPad X1', description: 'Lenovo business laptop', price: 1499, category: 'Laptops', rating: 4.5, in_stock: true, tags: ['lenovo', 'laptop'] },
];
// Single document
await client.collections('products').documents().create(documents[0]);
// Bulk import (JSONL)
const results = await client.collections('products').documents().import(documents, { action: 'upsert' });
console.log(results);
Search
// search.js: Search with typo tolerance, filters, and facets
const results = await client.collections('products').documents().search({
q: 'laptp', // typo-tolerant — matches "laptop"
query_by: 'name,description,tags',
filter_by: 'price:<2000 && in_stock:true',
sort_by: 'rating:desc',
facet_by: 'category,tags',
per_page: 10,
page: 1,
highlight_full_fields: 'name,description',
});
console.log(`Found ${results.found} results`);
results.hits.forEach(hit => {
console.log(hit.document.name, hit.highlights);
});
Python Client
# search.py: Typesense with Python client
import typesense
client = typesense.Client({
'nodes': [{'host': 'localhost', 'port': '8108', 'protocol': 'http'}],
'api_key': 'xyz123',
'connection_timeout_seconds': 5,
})
# Search
results = client.collections['products'].documents.search({
'q': 'laptop',
'query_by': 'name,description',
'filter_by': 'price:<2000',
'sort_by': 'rating:desc',
})
for hit in results['hits']:
print(hit['document']['name'], hit['document']['price'])
Geo Search
// geo-search.js: Location-based search with Typesense
// Collection must have a geopoint field: { name: 'location', type: 'geopoint' }
const results = await client.collections('stores').documents().search({
q: '*',
query_by: 'name',
filter_by: 'location:(48.8566, 2.3522, 10 km)',
sort_by: 'location(48.8566, 2.3522):asc',
});
Synonyms and Curation
// synonyms.js: Configure search synonyms and curations
// Synonyms
await client.collections('products').synonyms().upsert('laptop-synonyms', {
synonyms: ['laptop', 'notebook', 'portable computer'],
});
// Curate results — pin or hide specific documents for a query
await client.collections('products').overrides().upsert('featured-laptop', {
rule: { query: 'best laptop', match: 'exact' },
includes: [{ id: '1', position: 1 }],
excludes: [{ id: '99' }],
});
Docker Compose for Production
# docker-compose.yml: Typesense cluster with 3 nodes
services:
typesense-1:
image: typesense/typesense:27.1
ports:
- "8108:8108"
volumes:
- ts1-data:/data
command: >
--data-dir /data
--api-key=xyz123
--nodes=/config/nodes.txt
--peering-address=typesense-1
--peering-port=8107
volumes:
ts1-data: