Skip to main content

Python port of d3-array

Project description

pyd3js-array

PyPI version Python versions License CI Security

Python port of d3-array.

Tracked version: see upstream_lock.json.

What you get

  • 100% upstream export parity (for the pinned d3-array@3.2.4): the compatibility matrix below covers every upstream export; nothing is marked [missing].
  • 100% Python test coverage for pyd3js_array (run the coverage command below).
  • 100% upstream d3-array JS tests vendored and passing: the upstream Mocha suite under packages/pyd3js-array/upstream/d3-array/test/ is run via a pytest gate (-m upstream).

Install

From PyPI:

pip install pyd3js-array

This repo is a uv workspace monorepo. For local development:

uv sync --group dev

Usage

import pyd3js_array as ar

print(ar.extent([5, 1, 2, 3, 4]))
print(ar.min([5, 1, 2, 3, 4]))
print(ar.max([5, 1, 2, 3, 4]))
print(ar.range(2, 5))

print(ar.ticks(0, 1, 5))
print(ar.nice(0.2, 9.6, 5))

b = ar.bin().domain([0, 10]).thresholds([2, 4, 6, 8])
bins = b([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
print([(x.x0, x.x1, len(x)) for x in bins])

print(ar.bisectLeft([1, 2, 2, 3], 2))

people = [{"v": 1}, {"v": 2}, {"v": 2}, {"v": 3}]
print(ar.bisector(lambda d: d["v"]).right(people, 2))

print(ar.sum([1, 2, 3]))
print(ar.mean([1, 2, 3]))
print(ar.deviation([1, 2, 3]))
(1, 5)
1
5
[2.0, 3.0, 4.0]
[0.0, 0.2, 0.4, 0.6, 0.8, 1.0]
(0.0, 10.0)
[(0.0, 2.0, 2), (2.0, 4.0, 2), (4.0, 6.0, 2), (6.0, 8.0, 2), (8.0, 10.0, 3)]
1
3
6.0
2.0
1.0

Accessors receive (d, i, array) (mirroring D3):

import pyd3js_array as ar

data = [{"value": 3}, {"value": 1}, {"value": 2}]
print(ar.extent(data, lambda d, i, a: d["value"]))
(1, 3)

Stability & intentional deviations

  • Keyword conflicts: internally we use range_, but the public API exports it as range to match D3.
  • Oracle parity limits: oracle tests run through JSON, so some values (e.g. Infinity, -0, NaN) can’t be round-tripped reliably; those edge cases are covered with Python-only unit tests.
  • Non-determinism: shuffle() is tested via invariants (permutation + range) rather than exact oracle equality.

Compatibility matrix

Pinned upstream inventory: docs/UPSTREAM_API.md (from d3-array@3.2.4).

Legend:

  • [oracle]: implemented and has oracle parity tests for representative JSON-safe cases.
  • [unit-only: …]: implemented but oracle parity is blocked/limited (e.g. JSON round-trip, nondeterminism).
  • [missing]: reserved for future upstream drift (should not appear for the pinned version).

Upstream exports (d3-array@3.2.4)

  • Adder — [unit-only: non-JSON class]
  • InternMap — [oracle]
  • InternSet — [oracle]
  • ascending — [oracle]
  • bin — [oracle]
  • bisect — [oracle]
  • bisectCenter — [oracle]
  • bisectLeft — [oracle]
  • bisectRight — [oracle]
  • bisector — [oracle]
  • blur — [oracle]
  • blur2 — [oracle]
  • blurImage — [oracle]
  • count — [oracle]
  • cross — [oracle]
  • cumsum — [oracle]
  • descending — [oracle]
  • deviation — [oracle]
  • difference — [oracle]
  • disjoint — [oracle]
  • every — [oracle]
  • extent — [oracle]
  • fcumsum — [oracle]
  • filter — [oracle]
  • flatGroup — [oracle]
  • flatRollup — [oracle]
  • fsum — [oracle]
  • greatest — [oracle]
  • greatestIndex — [oracle]
  • group — [oracle]
  • groupSort — [oracle]
  • groups — [oracle]
  • histogram — [oracle]
  • index — [oracle]
  • indexes — [oracle]
  • intersection — [oracle]
  • least — [oracle]
  • leastIndex — [oracle]
  • map — [oracle]
  • max — [oracle]
  • maxIndex — [oracle]
  • mean — [oracle]
  • median — [oracle]
  • medianIndex — [oracle]
  • merge — [oracle]
  • min — [oracle]
  • minIndex — [oracle]
  • mode — [oracle]
  • nice — [oracle]
  • pairs — [oracle]
  • permute — [oracle]
  • quantile — [oracle]
  • quantileIndex — [oracle]
  • quantileSorted — [oracle]
  • quickselect — [oracle]
  • range — [oracle]
  • rank — [oracle]
  • reduce — [oracle]
  • reverse — [oracle]
  • rollup — [oracle]
  • rollups — [oracle]
  • scan — [oracle]
  • shuffle — [unit-only: nondeterministic]
  • shuffler — [oracle]
  • some — [oracle]
  • sort — [oracle]
  • subset — [oracle]
  • sum — [oracle]
  • superset — [oracle]
  • thresholdFreedmanDiaconis — [oracle]
  • thresholdScott — [oracle]
  • thresholdSturges — [oracle]
  • tickIncrement — [oracle]
  • tickStep — [oracle]
  • ticks — [oracle]
  • transpose — [oracle]
  • union — [oracle]
  • variance — [oracle]
  • zip — [oracle]

Testing

Run the package tests:

uv run pytest packages/pyd3js-array/tests

Coverage (Python)

uv run pytest packages/pyd3js-array/tests --cov=pyd3js_array --cov-report=term-missing

Oracle parity tests (Node)

Some tests compare behavior against real d3-array via the repo’s Node oracle:

cd tools/oracle && npm ci
uv run pytest -m oracle packages/pyd3js-array/tests

Notes:

  • Oracle tests must use JSON-safe values (avoid Infinity, -0, and NaN).
  • You can optionally enable local oracle caching by creating packages/pyd3js-array/.env with:
    • ORACLE_CACHE=1 (do not commit it).

Upstream d3-array test suite (vendored)

We vendor the pinned upstream d3-array repo (including its Mocha test suite) and run it via pytest.

uv run python scripts/vendor_upstream.py
cd packages/pyd3js-array/upstream/d3-array && npm install --legacy-peer-deps
uv run pytest -m upstream packages/pyd3js-array/tests

Documentation

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyd3js_array-0.1.1.tar.gz (5.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyd3js_array-0.1.1-py3-none-any.whl (56.3 kB view details)

Uploaded Python 3

File details

Details for the file pyd3js_array-0.1.1.tar.gz.

File metadata

  • Download URL: pyd3js_array-0.1.1.tar.gz
  • Upload date:
  • Size: 5.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for pyd3js_array-0.1.1.tar.gz
Algorithm Hash digest
SHA256 d2fae1c5f911fe8fd4eb367d2d0b38c322cec2224663c930a89eae172fba1d47
MD5 cd0bc54579d0df5ff1c21adc099bc0e6
BLAKE2b-256 50e8150e3028c188d75568113918acef3e654a5b8bbdb84a78a27e9b99314c06

See more details on using hashes here.

File details

Details for the file pyd3js_array-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: pyd3js_array-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 56.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for pyd3js_array-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7c34c83f2069d9be2adc2ed1fbcdc6a55706c6e649a71a9ffbf9a1c621cbc244
MD5 4491406b4b0921ce03e653b7ec4310ab
BLAKE2b-256 7ae764e5a67e5b4c2345710049939a19ae97310d7e1c57ec44812e8843190708

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page