geobuf是一种压缩的二进制地理空间格式,用于无损压缩geojson和topojson数据。

geobuf的Python项目详细描述


geobuf是压缩lossless的压缩二进制地理空间格式。 GeoJSON和TopoJSON数据。

Build StatusCoverage Status

note well:此项目不再积极开发。问题和 在可能的情况下,将处理拉取请求,但应延迟 预期。

与直接使用geojson和topojson相比的优势(在这里是revised version):

  • 非常紧凑:通常使geojson小6-8倍,并且 topojson小2-3倍。
  • 甚至在比较gzip大小时也更小:压缩2-2.5x GeoJSON和20-30%的TopoJSON。
  • 简单的增量解析-您可以在阅读时获得功能 它们不需要在内存中构建整个 数据。
  • 部分读取-您只能读取实际需要的部分, 跳过其余部分。
  • 平凡的连接:可以连接许多geobuf文件 它们一起将形成一个有效的组合geobuf文件。
  • 与本机json相比,编码/解码速度可能更快。 实现(即在web浏览器中)。
  • 仍然可以容纳任何geojson和topojson数据,包括 具有任意属性的扩展。

把这看作是设计一个简单、现代的形状文件的尝试 与geojson和topojson无缝工作的后续版本。

Mapbox Vector Tiles不同,它的目标是 无损压缩数据集-无平铺、投影 坐标、展平几何图形或剥离特性。

Pygeobuf

此存储库是此 新版Geobuf(in Python)。它是一个原型游乐场,速度更快 JS和C++在未来的实现。

样本压缩大小

| normal    | gzipped
us-zips.json101.85 MB26.67 MB
us-zips.pbf12.24 MB10.48 MB
us-zips.topo.json15.02 MB3.19 MB
us-zips.topo.pbf4.85 MB2.72 MB
idaho.json10.92 MB2.57 MB
idaho.pbf1.37 MB1.17 MB
idaho.topo.json1.9 MB612 KB
idaho.topo.pbf567 KB479 KB

使用量

命令行:

geobuf encode < example.json > example.pbf
geobuf decode < example.pbf > example.pbf.json

作为模块:

importgeobufpbf=geobuf.encode(my_json)# GeoJSON or TopoJSON -> Geobuf stringmy_json=geobuf.decode(pbf)# Geobuf string -> GeoJSON or TopoJSON

encode函数接受类似dict的对象,例如 json.loads(json_str)的结果。

encode.pygeobuf.encode都接受两个可选参数:

  • 精度-小数点后的最大位数 坐标,6默认。
  • dimensions-坐标中的维数,2by 违约。

测试

py.test -v

测试运行在fixtures目录中的所有.json文件中, 将每个原始geojson与一个编码/解码的geojson进行比较。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
字符串Java字母替换无效   java Spring Roo JPA MS SQL Server无法打开JPA EntityManager组织。冬眠例外GenericJDBCException:无法打开连接   在scala中使用JavaWS对大型数据文件进行java流式处理   Java编译器是否将字节和短字符识别为文本?   java无法查找符号错误,空指针   mongodb在Java中重用数据库连接   java将多个StringArray从字符串文件获取到活动中   java是一个变量,它只保存最后一次鼠标单击的坐标   c#尺寸有限;添加、删除和洗牌   java如何在Android中显示来自资产文件夹的文本文件中的文本   Android应用程序中的java Tensorflow Lite自定义对象检测模型错误   java如何在foreachloop中使用scanner将来自命令行的输入存储到数组中   java如何定义一个好的存储库接口   Android中的java解析动态json对象