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. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十天】(单点登录系统实现)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  2. oracle 查询表空间

    测试用户连接C:\Users\ZP>sqlplus /nologconn hbcxuser/hbcxpass --查看所有表空间 select * from user_tablespaces-- ...

  3. RDD(六)——分区器

    RDD的分区器 Spark目前支持Hash分区和Range分区,用户也可以自定义分区,Hash分区为当前的默认分区,Spark中分区器直接决定了RDD中分区的个数.RDD中每条数据经过Shuffle过 ...

  4. MySQL修改最大连接数的两个方法,偏爱第一种

    总结MySQL修改最大连接数的两个方式   最大连接数是可以通过mysql进行修改的,mysql数据库修改最大连接数常用有两种方法,今天我们分析一下这两种方法之间的特点和区别,以便我们能更好的去维护m ...

  5. springboot-security 登录 403

    之前一直使用shiro,刚开始使用security,大佬还请不要吐槽 security默认开启csrf防护,所谓csrf也就是伪请求.我们只需要把他关闭就好(因为我们的系统是在自己内网使用,不会有外部 ...

  6. springboot 整合thymeleaf 书笔记

    pom.xml依赖添加 <!--引入thymeleaf--> <dependency> <groupId>org.springframework.boot</ ...

  7. python Pandas Profiling 一行代码EDA 探索性数据分析

    文章大纲 1. 探索性数据分析 代码样例 效果 解决pandas profile 中文显示的问题 1. 探索性数据分析 数据的筛选.重组.结构化.预处理等都属于探索性数据分析的范畴,探索性数据分析是帮 ...

  8. AI动作捕捉技术,会让制造业大幅度降低成本吗?

    现代动作捕捉系统应该是起源于100多年前的动画工业,通过一种叫做"动态遮罩或影像描摹"的技术,动画师们可以获得流畅的.栩栩如生的动作:后来到了20世纪80年代,动画师们设计出带有活 ...

  9. nc命令的用法

    1.什么是nc netcat(nc)是一个简单而有用的工具,可以使用tcp或者udp进行网络间读写数据,传输文件,接收发送数据,验证网络是否畅通. 2.命令行: 1) -l 用于指定nc将处于侦听模式 ...

  10. 允许外部访问Windows本机的指定端口

    背景:目前公司有一台公网Windows服务器,有公网IP和内网IP,防火墙已开启 需求:9999端口需要对外开放 方案:在防火墙的入站规则里添加一条规则,使外部能够访问9999端口 问题:添加好规则后 ...