Geohash介绍

Geohash是一种地址编码,能把二维的经纬度编码成字符串,某一区域范围内的经纬度是一致的,其中有编码长度控制区域的范围 精度参考

使用场景

实时LBS应用

LBS应用中,搜索某某(地点) 附近 的什么(地点),重点在于附近,如果没有Geohash算法,你可能需要做。

  1. 圈定经度在某范围
  2. 圈定纬度在某范围
  3. 一般还会加上时间来做匹配

在数据量不多的时候这个方案确实可行,可是一旦数据量上去之后,这个方式别说实时应用甚至连离线场景都不合适。另外基本上应用基于LBS后,数据都是海量的。

所以通过对经纬度做Geohash成为字符串后,然后对该字符串以及时间在数据库中添加索引,再加上业内最常用的分库分表,即使海量基于LBS方面的数据实时查询也成为可行。

地理位置信息回溯

某打车公司,偶尔需要配合公安破案以及xx方面诉求的数据回溯,要调出某一时间段某一地区所有司机的信息,由于司机是实时上报坐标,数据量异常之大(日均几百G的,约500亿记录)

如果利用常规的圈定经度,纬度,时间范围的方式来查询根本不可行,所以利用Geohash在Hadoop中去查询的方式使得从大量数据中回溯特定数据方案可行。

当然这种诉求还有更佳的解决方案来做,由于并非高频需求,目前只是简单入Hive然后离线跑数据

简单使用

下边简单介绍在pythonphp中使用Geohash,以及遇到的问题

python

推荐使用Google上边的这个包,Download下来之后,解压到任意位置

1
2
3
4
5
6
7
8
9
10
11
12
13
16:02 liujb@localhost /Users/liujb/Dropbox/Didi/python-geohash
% ll
total 104
-rw-r--r--@ 1 liujb staff 25B Jan 15 15:14 MANIFEST.in
-rw-r--r--@ 1 liujb staff 3.7K Jan 15 15:14 README
-rw-r--r--@ 1 liujb staff 14K Jan 15 15:14 geohash.py
-rw-r--r--@ 1 liujb staff 11K Jan 15 15:15 geohash.pyc
-rw-r--r--@ 1 liujb staff 3.3K Jan 15 15:14 jpgrid.py
-rw-r--r--@ 1 liujb staff 2.1K Jan 15 15:14 jpiarea.py
-rw-r--r--@ 1 liujb staff 2.6K Jan 15 15:14 quadtree.py
-rw-r--r--@ 1 liujb staff 525B Jan 15 15:14 setup.py
drwxr-xr-x@ 6 liujb staff 204B Jan 15 15:14 src
drwxr-xr-x@ 7 liujb staff 238B Jan 15 15:14 test

然后在该目录

    大专栏  Geohash介绍i>输入python,进入python环境,
  1. 输入import geohash,导入geohash包
  2. print geohash.encode(30.725014, 104.257957)
  3. 得到wm6nu3q64mxr

整个过程如下

1
2
3
4
5
6
7
8
9
10
11
% python
Python 2.7.11 (default, Dec 12 2015, 20:37:07)
[GCC 4.2.1 Compatible Apple LLVM 7.0.2 (clang-700.1.81)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import geohash
>>> print geohash.encode(30.725014, 104.257957)
wm6nu3q64mxr
>>> print geohash.encode(30.725014, 104.257957, 5)
wm6nu
>>> print geohash.encode(30.735014, 104.267957)
wm6nuejs7mzg

看得出 30.725014, 104.25795730.735014, 104.267957 的hash值分别是wm6nu3q64mxr, wm6nuejs7mzg

两个字符串的前5位相同,两个地点相隔大约2公里左右

注意遇到的坑

1
2
3
4
5
6
7
8
9
10
11
>>> print geohash.encode(104.257957, 30.725014, 5)
File "<stdin>", line 1
print geohash.encode(104.257957, 30.725014, 5)
^
SyntaxError: invalid syntax
>>> print geohash.encode(104.257957, 30.725014, 5)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "geohash.py", line 79, in encode
raise Exception("invalid latitude.")
Exception: invalid latitude.

这是因为经纬度弄反了,所以geohash.encode()第一个参数是纬度,第二个参数是经度,第三个参数是编码长度。这个坑是因为一开始使用的是vinsci这个包,该包经纬度弄反了不会报错,也是会出来一个编码。当时并没有注意到该环节,导致匹配了很多很远的经纬度数据

php

参考此处

本文参考

Geohash介绍的更多相关文章

  1. lucene索引文件大小优化小结

    http://www.cnblogs.com/LBSer/p/4068864.html 随着业务快速发展,基于lucene的索引文件zip压缩后也接近了GB量级,而保持索引文件大小为一个可以接受的范围 ...

  2. 【算法】(查找你附近的人) GeoHash核心原理解析及代码实现

    本文地址 原文地址 分享提纲: 0. 引子 1. 感性认识GeoHash 2. GeoHash算法的步骤 3. GeoHash Base32编码长度与精度 4. GeoHash算法 5. 使用注意点( ...

  3. GeoHash原理解析

    GeoHash 核心原理解析       引子 一提到索引,大家脑子里马上浮现出B树索引,因为大量的数据库(如MySQL.oracle.PostgreSQL等)都在使用B树.B树索引本质上是对索引字段 ...

  4. 【转】GeoHash核心原理解析

    好久没更新过博客了,先转载一篇文章吧. 源地址:http://www.cnblogs.com/LBSer/p/3310455.html 引子 机机是个好动又好学的孩子,平日里就喜欢拿着手机地图点点按按 ...

  5. GeoHash核心原理解析

    http://www.cnblogs.com/LBSer/p/3310455.html 引子 机机是个好动又好学的孩子,平日里就喜欢拿着手机地图点点按按来查询一些好玩的东西.某一天机机到北海公园游玩, ...

  6. [转]GeoHash核心原理解析

    原文出处: zhanlijun    引子 机机是个好动又好学的孩子,平日里就喜欢拿着手机地图点点按按来查询一些好玩的东西.某一天机机到北海公园游玩,肚肚饿了,于是乎打开手机地图,搜索北海公园附近的餐 ...

  7. 基于GeoHash算法的附近点搜索实现(一)

    1. 引入 最近在参加学校的计算机仿真大赛,时间好像有点不够,所以只完成了前面的一部分最基础的功能,中途还是选择了放弃.但是之前的部分的确觉得完成得还不错,在这里分享一下.题目是要完成一个宇宙飞船加油 ...

  8. GeoHash核心解析

    GeoHash核心解析 引子 机机是个好动又好学的孩子,平日里就喜欢拿着手机地图点点按按来查询一些好玩的东西.某一天机机到北海公园游玩,肚肚饿了,于是乎打开手机地图,搜索北海公园附近的餐馆,并选了其中 ...

  9. 空间索引 - GeoHash算法及其实现优化

    h1,h2,h3,h4,h5,h6,p,blockquote { margin: 0; padding: 0 } body { font-family: "Helvetica Neue&qu ...

随机推荐

  1. java.lang.AbstractMethodError: org.slf4j.impl.JDK14LoggerAdapter.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;[Ljava/lang/Object;Ljava/lang/Throwable;)V

    java.lang.AbstractMethodError: org.slf4j.impl.JDK14LoggerAdapter.log(Lorg/slf4j/Marker;Ljava/lang/St ...

  2. Intellij IDEA中mybatis-generator自动生成

    一.在maven工程中的resource中创建generatorConfig.xml 二.配置generatorConfig.xml: <?xml version="1.0" ...

  3. MRP运算报错-清除预留

    MRP运算报错-清除预留

  4. 隐马尔可夫随机场HMM

    概率知识点: 0=<P(A)<=1 P(True)=1;P(False)=0 P(A)+P(B)-P(A and B) = P(A or B) P(A|B)=P(A,B)/P(B) =&g ...

  5. Linux的iptables菜鸟初学

    什么是iptables? iptables是linux下的命令行工具,操控的是linux的防火墙,这个防火墙叫netfilter.通俗的说应该是用户通过iptables把安全设定设置给netfilte ...

  6. VSTO开发中级教程 配套资源下载

    项目实例源代码: 编程过程中用到的工具.软件: 教学视频:

  7. STM32学习中出现的错误

    1.添加了多个文件后编译发现出现了无效的重复声明: 原因:文件(头文件)调用的时候重复调用, 解决办法:每个头文件写的时候包含以下代码: #ifndef   __STM32F10X_H   //头文件 ...

  8. LTE-U/LAA

    将LTE扩展至非授权频谱,得益于一个稳健的无线电通信线路,具有更好协调性的同步节点,以及以授权频谱为基点的载波聚合,LTE-U/LAA能提供比载波Wi-Fi更佳的网络性能和更强的用户体验,为移动运营商 ...

  9. idea,2018版破解方法

    1.准备安装文件 2.安装 ideaIU-2018.3.5.exe ,如这里是安装到IDEA这个文件夹: 3.复制JetbrainsIdesCrack-4.2-releasexxx.jar放到IDEA ...

  10. WebFilter 在springBoot工程中不起作用

    [1]@ServletComponentScan 必须有一个注解将带有@WebFilter的类包含进去. [2]自定义 FiltersConfig extends WebMvcConfigurerAd ...