Geoq is a command-line tool for working with geospatial data.
It combines common GIS serialization formats with utilities for manipulating and visualizing data on a map.
For example:
```sh
$ echo '{"type":"Polygon","coordinates":[[[-34,38],[-37,32],[-23,33],[-34,38]]]}' | geoq gh covering 2 -o {"type":"Polygon","coordinates":[[[30,10],[40,40],[20,40],[10,20],[30,10]]]} eq en em ej
$ echo '{"type":"Polygon","coordinates":[[[-34,38],[-37,32],[-23,33],[-34,38]]]}' | geoq gh covering 2 -o | geoq map ```
See the Manual for more examples and available commands.
Currently installation is done through crates.io, the Rust package repository.
If you have Rust installed, simply:
cargo install geoq
To install Rust and the Cargo toolchain:
curl https://sh.rustup.rs -sSf | sh
You'll also need to add Cargo's bin
directory to your path:
```
export PATH="$HOME/.cargo/bin:$PATH" ```
To pull and install a newer version from crates.io, run:
cargo install geoq --force
Geoq will detect the following GIS input formats automatically:
34.0,-118.0
9q5
POINT (-118.0, 34.0)
{"type": "Point", "coordinates": [-118.0, 34.0]}
Geoq processes text inputs on a per-line basis, and it expects inputs not to stretch across multiple lines.
This sometimes causes problems, especially with GeoJSON, because many JSON processing tools like to output pretty-printed JSON in a multi-line format.
One way to fix this problem with pretty-printed GeoJSON is to use the jq tool:
echo '{
"type": "Point",
"coordinates": [30, 10]
}
' | jq -c . | geoq map
See the built-in command help using geoq --help
or geoq <subcommand> --help
for more detailed information on these:
bbox
- Give bounding boxes for geometries, or for a stream of geometries collectivelycentroid
- Cet the centroid of a geometryfilter
- Spatial predicate filtering
intersects
- Select features intersecting a given query geometrycontains
- Select features contained by a given query geometrygh
- Geohash subcommands
children
- Get children of a geohashcovering
- Output geohashes that "cover" a geometryneighbors
- Get neighbors of a Geohashpoint
- Output base 32 Geohash for a given Lat,Longj
- GeoJSON subcommands
f
- Output geometry as GeoJSON featuregeom
- Output geometry as GeoJSON geometryfc
- Collect all input geometries into a GeoJSON Feature Collectionjson
- JSON -> GeoJSON coercion
munge
- Attempt to convert arbitrary JSON to a GeoJSON Feature.map
- Visualization with geojson.iomeasure
- Measurement subcommands
distance
- Measure distances between featurescoord-count
- Give the number of vertices in geometriesread
- Debugging / format validationshp
- Convert shapefiles to GeoJSONsimplify
- Simplify geometries, either with fixed threshold or iteratively toward target coord-countwhereami
- Output IP geolocation-based current lat/lon as GeoJSONwkt
- Output geometries as WKTSee the Manual for more examples and available commands.
cargo test
cargo publish
git tag release/<VERSION>
git push origin release/<VERSION>