--- layout: tap site_name: tap tap_name: table description: "Format rows as a human-readable table (outputs one row per line)" intent: read columns: [] args: - name: cols type: string description: "Columns to show (comma-separated, default: all)" - name: max type: string default: 40 description: "Max column width" args_json: | {"cols":{"type":"string","default":"","description":"Columns to show (comma-separated, default: all)"},"max":{"type":"string","default":"40","description":"Max column width"}} health_json: | {"min_rows":1,"non_empty":[]} example_args: "" source_url: https://github.com/LeonTing1010/tap-skills/blob/main/showcase/tap/table.plan.json license: MIT ---

What it does

Format rows as a human-readable table (outputs one row per line)

Install Taprun once

Taprun ships as a single MCP server exposing a catalog of compiled taps. One-time setup on macOS / Linux:

brew install LeonTing1010/tap/taprun
tap mcp connect

Or drop this into your claude_desktop_config.json (works identically in Claude Code, Cursor, Cline, Windsurf — any MCP host):

{
  "mcpServers": {
    "tap": {
      "command": "tap",
      "args": ["mcp", "start"]
    }
  }
}

Call tap/table

Terminal, once installed:

tap run tap/table

From the MCP host — exact same compiled plan, deterministic replay, zero LLM tokens:

tap.run({ site: "tap", name: "table" })

Why compile it once

This plan was forged once — the AI read tap, picked stable structural addresses (JSON-LD, ARIA, RSS, or declared API endpoints, in that priority order), and saved them to a .plan.json. Every replay since then has used zero LLM tokens. When tap ships a site change that breaks the extraction, tap verify surfaces it before your data goes stale — not after your pipeline silently writes garbage for a week.

Related tap taps

tapdescription
tap/filterFilter rows where field matches condition (gt, lt, eq, contains)
tap/sortSort rows by field (numeric or alphabetic, asc or desc)
tap/pickSelect specific columns from rows (projection)
tap/limitTake first N rows (head) or skip M then take N (offset+limit)
tap/dedupeRemove duplicate rows by field value