|
/ j$ ~: q" _+ U
在地理空间数据分析中,常会用到许多地理分析的工具,在本模块中主要是针对常用的shapely、geopandas、folium、kepler.gl、geohash等工具进行简单介绍。其中shapely和geopandas是做地理空间数据的分析很好的工具,而folium和kepler.gl是进行地理数据可视化的工具,geohash是将经纬度坐标进行数据编码的方式。通过了解不同的方法将有助于我们去思考如何在现有的工具下去做数据的分析和特征的提取功能
6 R% Y3 q! A N" v/ @& J3 X( v 学习目标¶
4 ~# B4 m( X; g8 P, G 1.了解和学习shapely和geopandas的基本功能,掌握用python中的这两个库实现几何对象之间的空间操作方法。 5 k2 H; j8 C" O4 W
2.掌握folium和kepler.gl的数据可视化工具的使用。
. ^+ S! ?# @! N0 q& v& k" J 3.学习与掌握geohash编码方法。
0 s% y9 H; I0 c. S1 }( [5 Y* [9 F python包安装 , u7 ]0 n4 {6 r& u+ e+ ^
1、创建虚拟环境
* U8 `9 _) q* l 在anaconda prompt中,执行
( j0 I4 f' I1 I# O) n5 J7 A2 X - conda create -n wisdomOcean python=3.6 2 ?4 [! p, B5 Y0 \7 H9 I
- activate wisdomOcean 0 }5 z/ m, Z" x2 R, ~( [! R
- pip install numpy
4 ~1 T; |: q& `' D4 a - pip install shapely
9 F& }( U5 ]5 |( ^1 a9 O! X) m: n - conda install geopandas=0.9.0 -c https://mirrors.sjtug.sjtu.edu.cn/anaconda/cloud/conda-forge -y
" m8 r; D9 W9 _0 D - conda install folium -c conda-forge
' p& H& ^' O: Y& D6 N 2、geopandas安装 ; L& a* g' O9 ]) J- a: [
- 地址:https://www.lfd.uci.edu/~gohlke/pythonlibs/#pyproj
$ Q' @- i D# `* a - 下载版本:使用与Python 3.6 / ]# x! P6 T, N( m# \8 ~* n
- Fiona-1.8.13-cp36-cp36m-win_amd64.whl
8 B& x, U% G* {) a2 s. {" y; h - GDAL-3.0.4-cp36-cp36m-win_amd64.whl " B' u: N/ h( a, Q# x7 p
- geopandas-0.9.0-py3-none-any.whl
# R9 \7 s+ z; l2 U7 D4 {' X - pyproj-2.4.2.post1-cp36-cp36m-win_amd64.whl
. L K+ |+ ^/ h/ q1 O- K+ E x/ ] - 用pip分别进行安装 pip install GDAL-3.0.4-cp36-cp36m-win_amd64.whl Fiona-1.8.13-cp36-cp36m-win_amd64.whl pyproj-2.4.2.post1-cp36-cp36m-win_amd64.whl geopandas-0.9.0-py3-none-any.whl
- g; {* ]' N0 p% s: x5 k: w; X - pip install -i https://pypi.tuna.tsinghua.edu.cn/simple geopandas
/ h0 j% D# I6 ]; U5 E 3、keplergl安装
# W' z# _' Y5 c/ t6 u" p" U/ k9 \ - pip install -i https://pypi.tuna.tsinghua.edu.cn/simple ipywidgets==7.4.2
7 a% g" f1 I( z x3 C - pip install -i https://pypi.tuna.tsinghua.edu.cn/simple traitlets4.3.2
# j2 A z, R1 Y y - pip install -i https://pypi.tuna.tsinghua.edu.cn/simple traittypes==0.2.1
0 O# z6 h, [ K9 B/ u- P" q5 Q7 _ - pip install -i https://pypi.tuna.tsinghua.edu.cn/simple keplergl
1 N8 \- `& g1 i6 J7 { - pip install npm
+ f) H8 E4 l. Z+ q, _8 j7 ~ 注:除了安装keplergl,还需要安装node.jshttps://nodejs.org/en/download/下载node.js安装即可
+ S' A3 ^& C7 ]+ I! H7 P! ?" ^+ F 导入包 " z( q8 M# E' ]& M! S& j
+ C9 _1 u: W1 q4 \
#这一行代码不用运行,github上有已经运行的csv文件 7 I% J2 k4 t( Q: p
读入文件 ' B7 {/ U5 o& s1 K) t# h ~
df_gpd_change=pd.read_csv(rC:\Users\admin\df_gpd_change.csv)
6 @- C, |+ I* s& I$ z 作业一:尝试去使用kepler.gl可视化来分析不同类型船舶AIS数据的分布情况
( b& \ M& l; B7 \7 s1 |
/ d- `: H/ [" g8 Y+ q# p
/ a) W6 S6 D& F1 @3 }7 d! }+ C: J * W! e$ ?' m* c) v( d/ J; g% S( W
. V5 B0 S: Z( R: p2 R
( Q8 m P8 r9 j3 R
8 C: D* M9 {# _% I& V2 z6 Q1 C
; x7 X* M. b6 I+ }: M8 z! m. j |