npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

zhv-json

v1.0.1

Published

JSON-Version des von DELFI e.V zusammengetragenen Zentralen Haltestellen Verzeichnisses (ZHV)

Downloads

10

Readme

zHv-parser

Javascript-Parser des von DELFI e.V zusammengetragenen Zentralen Haltestellen Verzeichnisses (ZHV).

API

zum bequemen abfragen der daten und suche nahegelegener haltestellen...

kommt morgen, ok? es ist grade 4 uhr morgens. also ruhe jetz, ja?

JSON Format

Die Library enthält die jetzigen Stationsinformationen als json-dateien. (siehe unten für automatische erzeugung )

Es folgt eine erklärung der Dateien:

stations.json

Enthält alle Haltestellen, Bereiche und Gleise/Halte-Masten. (Bereiche werden zur gruppierung mehrerer Gleise genutzt, glaube ich) Die Datei enthält ein Object/Dictionary, dass jeweils die DHID (Dauerhafte Haltestellen-Id) als "Key" und ein Haltestellen-Objekt als "Value" hat. image

Haltestellen-Objekt

  • n: String Der Name der Haltestelle
  • i: String Der Teil der DHID, die nicht schon in der Gemeinde-Nummer steckt (platzsparmaßnahme halt)
  • c: [Latitude, Longitude] Koordinaten, verpackt in einem Array der Länge 2, als Kommazahlen
  • m: Number Municipality-Id - Die Gemeinde Nummer
    • Format: bbkkksss [b=bundesland, k=kreisnummer, s=stadtnummer] mehr erfahren
    • (wenn die bundeslandnummer einstellig ist, ist die nummer 7 und nicht 8 stellig)
    • Mit dieser nummer kann die DHID rekonstruiert werden: "de":bbkkk:i (hier muss eine null vorne stehen, wenn das bundesland einstellig ist)
    • Beispiel: rekonstruiert: "de:07334:30658"; i-Wert: "30130"; m-Wert: 7334034
  • d: Number District-Id - Die Stadtteilnummer
    • Diesen Wert scheint niemand zu benutzen? An einigen stellen ist er definiert aber ohne entsprechenden Stadteilnamen also pfff
  • a: Number Autorität-Id (Position im Array von authorities.json) (platzsparen, wie gesagt ne)
  • des: String die Beschreibung. (selten angegeben)
  • s : Boolean Ist die Haltestelle in Betrieb? Dieser Wert ist undefiniert, wenn sie in Betrieb sind (platz, natürlich, darum gehts doch immer)
  • b: Object/Dictionary<String, Bereich> Bereiche (Quasi wie DateiOrdner für gleise und masten)

Haltestellen halten ihre Bereiche in der b-Eigenschaft, Bereiche ihre Gleise in der g Eigenschaft. Die Bereichs und Gleisobjekte haben dieselbe struktur, außer das einige werte fehlen: a, m, d und i.

Aufgerolltes Beispiel der HAltestellen>Bereich>Gleis Struktur: image

Wichtig: Der Schlüssel der Bereiche und Gleise Objekten entspricht jeweils einem Teil der DHID D.h Gleis-DHID: "de:07334:1734:1:1", Pfad: haltestellen["de:07334:1734"].b.1.g.1

Beispiele für einzelne Haltestellen finden sie in examples.json.

Eine für die ersten 500 Zeilen lesbar formatierte version der Dateien finden sie jeweils mit dem -Debug suffix.

municipalities.json

Die datei, wenn man anhand der gemeindeschlüssel den namen nachgucken möchte. Im /wikidata/regions.json sind außerdem alle bundesländer und landkreise in einer baumstruktur aufgelistet

Ein Objekt, Schlüssel sind die Gemeindenummern (siehe oben), Wert ist je das Gemeindeobjekt:

  • n GemeindeName
  • d Distrikte (überall leer keine ahnung)
  • a Array der Autoritäten, die hier haltestellen angemeldet haben (idR nur ein eintrag), wie oben referenz zu authorities.json

authorities.json

Ein Array der Autoritätennamen: Oben gennante a-Eigenschaften verweisen auf diesen Array ["NVBW","BEG","VBB","VBN","Hamburger Hochbahn","rms","VMV","VRR","HannIT","VRN","ZPS","NASA","VVO","VMT","NVV"]

Build Befehl

Die library enthält bereits alle fertigen JSON-Dateien. Falls sie jedoch die aktuellsten Daten des ZHV im JSON format brauchen, besuchen sie das ZHV, erstellen sie einen Account, und laden in der Tabellenansicht das komplette Verzeichnis als .csv datei herunter.

Klonen Sie diese Repo, legen Sie den Ordner /rawdata an und die .csv datei hinein. Öffen sie das terminal, navigieren sie zum library ordner und führen Sie den Befehl node . <dateiname>.csv aus. Nun werden die DELFI-Daten gelesen und im kompakten JSON Format in den /refineddata Ordner gelegt.