faker
テストやデータベース構築、試作などで、名前や住所のような本物に近い偽のデータを手軽に作りたい時に、fakerというツールを使って、リアリティのあるテストデータやサンプルデータを自動生成するSkill。
📜 元の英語説明(参考)
When the user wants to generate realistic fake data for testing, seeding databases, or prototyping. Also use when the user mentions "faker," "fake data," "test data generation," "seed data," "mock data," "random names," or "realistic test data." For API mocking, see mockoon or wiremock.
🇯🇵 日本人クリエイター向け解説
テストやデータベース構築、試作などで、名前や住所のような本物に近い偽のデータを手軽に作りたい時に、fakerというツールを使って、リアリティのあるテストデータやサンプルデータを自動生成するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o faker.zip https://jpskill.com/download/14885.zip && unzip -o faker.zip && rm faker.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/14885.zip -OutFile "$d\faker.zip"; Expand-Archive "$d\faker.zip" -DestinationPath $d -Force; ri "$d\faker.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
faker.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
fakerフォルダができる - 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
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
Faker
概要
あなたは Faker.js (@faker-js/faker) のエキスパートです。これは、現実的な偽のデータを生成するためのライブラリです。あなたは、複数のロケールにわたって、名前、メール、住所、日付、商取引データなどを生成するユーザーを支援します。あなたは、再現可能なデータのためのシーディング、カスタムジェネレーターの作成、バルクデータセットの生成、およびテスト、データベースシーダー、Storybook ストーリーでの Faker の使用を理解しています。
指示
初期評価
- 目的 — テスト、データベースシーディング、プロトタイピング、またはデモですか?
- 言語 — JavaScript/TypeScript、Python、Ruby、PHP、またはその他ですか?
- データ形状 — どのようなエンティティに偽のデータが必要ですか? (users, products, orders)
- ロケール — どの言語/地域ですか? (en, de, fr, ja, etc.)
セットアップ
# setup-faker.sh — Faker.js をインストールします。
npm install --save-dev @faker-js/faker
基本的な使い方
// generate-data.ts — 一般的なデータ型に対する基本的な Faker.js の使い方。
// 名前、メール、住所などを生成します。
import { faker } from '@faker-js/faker';
const user = {
id: faker.string.uuid(),
firstName: faker.person.firstName(),
lastName: faker.person.lastName(),
email: faker.internet.email(),
avatar: faker.image.avatar(),
phone: faker.phone.number(),
address: {
street: faker.location.streetAddress(),
city: faker.location.city(),
state: faker.location.state(),
zip: faker.location.zipCode(),
country: faker.location.country(),
},
company: faker.company.name(),
jobTitle: faker.person.jobTitle(),
bio: faker.lorem.paragraph(),
createdAt: faker.date.past(),
};
console.log(user);
コレクションの生成
// generate-users.ts — 一貫した形状を持つ偽のユーザーの配列を生成します。
// データベースのシーディングやテストフィクスチャの作成に役立ちます。
import { faker } from '@faker-js/faker';
interface User {
id: string;
name: string;
email: string;
role: 'admin' | 'user' | 'moderator';
isActive: boolean;
createdAt: Date;
}
function createRandomUser(): User {
return {
id: faker.string.uuid(),
name: faker.person.fullName(),
email: faker.internet.email().toLowerCase(),
role: faker.helpers.arrayElement(['admin', 'user', 'moderator']),
isActive: faker.datatype.boolean({ probability: 0.8 }),
createdAt: faker.date.between({ from: '2023-01-01', to: new Date() }),
};
}
const users = faker.helpers.multiple(createRandomUser, { count: 100 });
console.log(`Generated ${users.length} users`);
シードによる再現可能なデータ
// seeded-data.ts — テスト実行全体で再現可能な偽のデータにシードを使用します。
// 同じシードは常に同じデータを生成します。
import { faker } from '@faker-js/faker';
faker.seed(42);
const user1 = faker.person.fullName();
const email1 = faker.internet.email();
// 異なるが同様に再現可能なセットのためにシードをリセットします
faker.seed(123);
const user2 = faker.person.fullName();
複数のロケール
// localized-data.ts — さまざまな言語とロケールで偽のデータを生成します。
// 各ロケールは、文化的に適切な名前、住所などを生成します。
import { faker, fakerDE, fakerFR, fakerJA } from '@faker-js/faker';
const germanUser = {
name: fakerDE.person.fullName(),
address: fakerDE.location.streetAddress(),
phone: fakerDE.phone.number(),
};
const frenchUser = {
name: fakerFR.person.fullName(),
city: fakerFR.location.city(),
};
const japaneseUser = {
name: fakerJA.person.fullName(),
city: fakerJA.location.city(),
};
データベースシーダー
// seeds/seed-database.ts — 現実的なテストデータのために Faker を使用したデータベースシーダー。
// 適切な関係を持つユーザー、製品、および注文を作成します。
import { faker } from '@faker-js/faker';
import { db } from '../src/db';
async function seed() {
faker.seed(42);
const userIds: string[] = [];
for (let i = 0; i < 50; i++) {
const [user] = await db('users').insert({
name: faker.person.fullName(),
email: faker.internet.email().toLowerCase(),
avatar_url: faker.image.avatar(),
created_at: faker.date.past({ years: 2 }),
}).returning('id');
userIds.push(user.id);
}
const productIds: string[] = [];
for (let i = 0; i < 200; i++) {
const [product] = await db('products').insert({
name: faker.commerce.productName(),
description: faker.commerce.productDescription(),
price: parseFloat(faker.commerce.price({ min: 5, max: 500 })),
category: faker.commerce.department(),
image_url: faker.image.urlPicsumPhotos(),
in_stock: faker.datatype.boolean({ probability: 0.85 }),
}).returning('id');
productIds.push(product.id);
}
for (let i = 0; i < 500; i++) {
const userId = faker.helpers.arrayElement(userIds);
const itemCount = faker.number.int({ min: 1, max: 5 });
const [order] = await db('orders').insert({
user_id: userId,
status: faker.helpers.arrayElement(['pending', 'confirmed', 'shipped', 'delivered']),
total: 0,
created_at: faker.date.recent({ days: 90 }),
}).returning('id');
let total = 0;
for (let j = 0; j < itemCount; j++) {
const productId = faker.helpers.arrayElement(productIds);
const quantity = faker.number.int({ min: 1, max: 3 });
const price = parseFloat(faker.commerce.price({ min: 5, max: 100 }));
total += price * quantity;
await db('order_items').insert({
order_id: order.id,
product_id: productId,
quantity,
price,
});
}
await db('orders').where({ id: order.id }).update({ total });
}
console.log('Seeded: 50 users, 200 products, 500 orders');
}
seed().then(() => process.exit(0));
テストでの使用
// tests/user-service.test.ts — ランダムだが現実的なデータのためにユニットテスト内で Faker を使用します。
// 各テストは一意のデータを取得します。デバッグ時には再現性のためにシードします。
import { faker } from '@faker-js/faker';
import { UserService } from '../src/services/userService';
describe('UserService', () => {
const service = new UserService();
(原文がここで切り詰められています) 📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Faker
Overview
You are an expert in Faker.js (@faker-js/faker), the library for generating realistic fake data. You help users generate names, emails, addresses, dates, commerce data, and more across multiple locales. You understand seeding for reproducible data, creating custom generators, generating bulk datasets, and using Faker in tests, database seeders, and Storybook stories.
Instructions
Initial Assessment
- Purpose — Testing, database seeding, prototyping, or demos?
- Language — JavaScript/TypeScript, Python, Ruby, PHP, or other?
- Data shape — What entities need fake data? (users, products, orders)
- Locale — Which language/region? (en, de, fr, ja, etc.)
Setup
# setup-faker.sh — Install Faker.js.
npm install --save-dev @faker-js/faker
Basic Usage
// generate-data.ts — Basic Faker.js usage for common data types.
// Generates names, emails, addresses, and more.
import { faker } from '@faker-js/faker';
const user = {
id: faker.string.uuid(),
firstName: faker.person.firstName(),
lastName: faker.person.lastName(),
email: faker.internet.email(),
avatar: faker.image.avatar(),
phone: faker.phone.number(),
address: {
street: faker.location.streetAddress(),
city: faker.location.city(),
state: faker.location.state(),
zip: faker.location.zipCode(),
country: faker.location.country(),
},
company: faker.company.name(),
jobTitle: faker.person.jobTitle(),
bio: faker.lorem.paragraph(),
createdAt: faker.date.past(),
};
console.log(user);
Generating Collections
// generate-users.ts — Generate an array of fake users with consistent shape.
// Useful for seeding databases or populating test fixtures.
import { faker } from '@faker-js/faker';
interface User {
id: string;
name: string;
email: string;
role: 'admin' | 'user' | 'moderator';
isActive: boolean;
createdAt: Date;
}
function createRandomUser(): User {
return {
id: faker.string.uuid(),
name: faker.person.fullName(),
email: faker.internet.email().toLowerCase(),
role: faker.helpers.arrayElement(['admin', 'user', 'moderator']),
isActive: faker.datatype.boolean({ probability: 0.8 }),
createdAt: faker.date.between({ from: '2023-01-01', to: new Date() }),
};
}
const users = faker.helpers.multiple(createRandomUser, { count: 100 });
console.log(`Generated ${users.length} users`);
Reproducible Data with Seeds
// seeded-data.ts — Use seeds for reproducible fake data across test runs.
// Same seed always produces the same data.
import { faker } from '@faker-js/faker';
faker.seed(42);
const user1 = faker.person.fullName();
const email1 = faker.internet.email();
// Reset seed for a different but equally reproducible set
faker.seed(123);
const user2 = faker.person.fullName();
Multiple Locales
// localized-data.ts — Generate fake data in different languages and locales.
// Each locale produces culturally appropriate names, addresses, etc.
import { faker, fakerDE, fakerFR, fakerJA } from '@faker-js/faker';
const germanUser = {
name: fakerDE.person.fullName(),
address: fakerDE.location.streetAddress(),
phone: fakerDE.phone.number(),
};
const frenchUser = {
name: fakerFR.person.fullName(),
city: fakerFR.location.city(),
};
const japaneseUser = {
name: fakerJA.person.fullName(),
city: fakerJA.location.city(),
};
Database Seeder
// seeds/seed-database.ts — Database seeder using Faker for realistic test data.
// Creates users, products, and orders with proper relationships.
import { faker } from '@faker-js/faker';
import { db } from '../src/db';
async function seed() {
faker.seed(42);
const userIds: string[] = [];
for (let i = 0; i < 50; i++) {
const [user] = await db('users').insert({
name: faker.person.fullName(),
email: faker.internet.email().toLowerCase(),
avatar_url: faker.image.avatar(),
created_at: faker.date.past({ years: 2 }),
}).returning('id');
userIds.push(user.id);
}
const productIds: string[] = [];
for (let i = 0; i < 200; i++) {
const [product] = await db('products').insert({
name: faker.commerce.productName(),
description: faker.commerce.productDescription(),
price: parseFloat(faker.commerce.price({ min: 5, max: 500 })),
category: faker.commerce.department(),
image_url: faker.image.urlPicsumPhotos(),
in_stock: faker.datatype.boolean({ probability: 0.85 }),
}).returning('id');
productIds.push(product.id);
}
for (let i = 0; i < 500; i++) {
const userId = faker.helpers.arrayElement(userIds);
const itemCount = faker.number.int({ min: 1, max: 5 });
const [order] = await db('orders').insert({
user_id: userId,
status: faker.helpers.arrayElement(['pending', 'confirmed', 'shipped', 'delivered']),
total: 0,
created_at: faker.date.recent({ days: 90 }),
}).returning('id');
let total = 0;
for (let j = 0; j < itemCount; j++) {
const productId = faker.helpers.arrayElement(productIds);
const quantity = faker.number.int({ min: 1, max: 3 });
const price = parseFloat(faker.commerce.price({ min: 5, max: 100 }));
total += price * quantity;
await db('order_items').insert({
order_id: order.id,
product_id: productId,
quantity,
price,
});
}
await db('orders').where({ id: order.id }).update({ total });
}
console.log('Seeded: 50 users, 200 products, 500 orders');
}
seed().then(() => process.exit(0));
Using in Tests
// tests/user-service.test.ts — Using Faker inside unit tests for random but realistic data.
// Each test gets unique data; seed for reproducibility when debugging.
import { faker } from '@faker-js/faker';
import { UserService } from '../src/services/userService';
describe('UserService', () => {
const service = new UserService();
it('should validate email format', () => {
const validEmail = faker.internet.email();
expect(service.isValidEmail(validEmail)).toBe(true);
const invalidEmail = faker.person.firstName();
expect(service.isValidEmail(invalidEmail)).toBe(false);
});
it('should create user with all fields', async () => {
const input = {
name: faker.person.fullName(),
email: faker.internet.email(),
age: faker.number.int({ min: 18, max: 99 }),
};
const user = await service.create(input);
expect(user.name).toBe(input.name);
expect(user.email).toBe(input.email);
expect(user.id).toBeDefined();
});
});
Custom Helpers
// helpers/fake-helpers.ts — Custom Faker helpers for domain-specific data.
// Generates application-specific entities like subscriptions and invoices.
import { faker } from '@faker-js/faker';
export function fakeSubscription() {
const plans = ['free', 'pro', 'enterprise'] as const;
const plan = faker.helpers.arrayElement(plans);
return {
id: faker.string.uuid(),
plan,
price: plan === 'free' ? 0 : plan === 'pro' ? 19.99 : 99.99,
startDate: faker.date.past(),
renewalDate: faker.date.future(),
isActive: faker.datatype.boolean({ probability: 0.9 }),
};
}
export function fakeInvoice() {
return {
id: `INV-${faker.string.alphanumeric(8).toUpperCase()}`,
amount: parseFloat(faker.finance.amount({ min: 10, max: 5000 })),
currency: faker.finance.currencyCode(),
status: faker.helpers.arrayElement(['draft', 'sent', 'paid', 'overdue']),
dueDate: faker.date.soon({ days: 30 }),
lineItems: faker.helpers.multiple(
() => ({
description: faker.commerce.productName(),
quantity: faker.number.int({ min: 1, max: 10 }),
unitPrice: parseFloat(faker.commerce.price()),
}),
{ count: { min: 1, max: 5 } }
),
};
}