loading…
Search for a command to run...
loading…
MCP server for calculating XIRR (Extended Internal Rate of Return) from cash flows and Rakuten Securities CSV, enabling natural language portfolio performance q
MCP server for calculating XIRR (Extended Internal Rate of Return) from cash flows and Rakuten Securities CSV, enabling natural language portfolio performance queries.
MCP server for XIRR (Extended Internal Rate of Return) calculation, with built-in support for Rakuten Securities (楽天証券) transaction CSV.
Plug it into Claude Desktop or Claude Code, hand it a CSV exported from your brokerage, and ask:
「この CSV と現在の評価額 ¥1,500,000 で、実績年利を計算して」
Claude will compute the XIRR for you — accounting for irregular contributions and withdrawals — and explain the result.
calculate_xirr — XIRR from arbitrary cash flow series + current valuationparse_rakuten_csv — Parse Rakuten Securities transaction CSV (取引履歴) into normalized cash flowsnpx commandEdit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"xirr": {
"command": "npx",
"args": ["-y", "@kimagure-dd/xirr-mcp"]
}
}
}
Restart Claude Desktop. The calculate_xirr and parse_rakuten_csv tools should appear.
claude mcp add xirr -- npx -y @kimagure-dd/xirr-mcp
Ask Claude:
「以下のキャッシュフローで XIRR を計算して。2020-01-01 に 100万円投資、2022-01-01 に 50万円追加、現在(2025-01-01)の評価額 200万円」
Claude will call calculate_xirr with structured input and return:
{
"annualRate": 12.34,
"annualRateFormatted": "12.34%",
"totalInvestment": 1500000,
"totalGain": 500000,
"gainRateFormatted": "33.33%",
"converged": true
}
Claude will pipe the CSV through parse_rakuten_csv → calculate_xirr automatically.
calculate_xirrCalculates XIRR from a list of dated cash flows and a current valuation.
Input:
| Field | Type | Description |
|---|---|---|
cashFlows |
array | List of { date, amount }. Positive = invested, negative = withdrawn. |
currentValue |
number | Current portfolio valuation. |
valuationDate |
string | YYYY-MM-DD. Date of currentValue. |
Output:
| Field | Type | Description |
|---|---|---|
annualRate |
number | Annualized return as a percentage. |
monthlyRate |
number | Monthly rate (compounded to annual). |
totalInvestment |
number | Sum of all cash flows. |
totalGain |
number | currentValue - totalInvestment. |
gainRate |
number | Total gain as a percentage of investment. |
converged |
boolean | True if the iterative solver converged. |
parse_rakuten_csvParses a Rakuten Securities transaction CSV.
Input:
| Field | Type | Description |
|---|---|---|
csvContent |
string | Raw CSV text (UTF-8 decoded). |
Required CSV headers:
約定日, 取引, ファンド名, 受渡金額/(ポイント利用)[円]
Behavior:
買付 rows → positive amount (investment)売却) → negative amount (withdrawal)The same logic is used in the browser-based XIRR calculator on kimagure-dd.dev, so results are identical.
This tool computes investment performance for informational purposes only. Taxes, transaction fees, and currency conversion are not considered. The output does not constitute investment advice.
npm install
npm run build
npm test
To test the server locally before publishing:
npm pack
# Then point Claude Desktop to the .tgz path
MIT © kimagure-dd
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"kimagure-dd-xirr-mcp": {
"command": "npx",
"args": []
}
}
}