Python

GeoDjango2.1学习笔记

2019-01-25  本文已影响0人  假装我不帅
第一天
python django-admin startproject agsicom
python manage.py startapp reporter

settings.py

installed_apps=[
"reporter",
]

reporter app下的models.py添加如下代码:

class Incidences(models.Model):
    name=models.CharField(max_length=20)
    location=models.CharField(max_length=20) 
    def __unicode__(self):
        return self.name
    class Meta:
        verbose_name_plural="Incidences"
        #更改localhost:8000/admin下的显示样式
python manage.py migrate
python manage.py runserver

访问localhost:8000

python manage.py createsuperuser

用户名
密码

python manage.py runserver

localhost:8000/admin
登录进去看看
reporter app下的admin.py写入如下代码

from .models import  Incidences
class IncidencesAdmin(admin.ModelAdmin):
    list_display=("name","location")
admin.site.register(Incidences,IncidencesAdmin)

#注册
访问localhost:8000/admin出错

python manage.py makemigrations
python manage.py migrate

再次登录
添加一组数据
name="泰安"
location="山东"
配套视频1
配套视频2
B站连接
看不清可以切换一下清晰度

第二天
database={
'default':{
'ENGINE':'django.contrib.gis.db.backends.postgis',
'NAME':'agricom',#数据库名字
'USER':'postgres',
'PASSWORD':'wujialiang',
'HOST':'localhost',
'PORT':'5432',
}
}

pip install psycopg2
这是数据库没有建立,建立数据库
没安装数据库先安装数据库
windows下安装postgresql非常简单,去官网下载对应版本,直接下一步,中途需要输入用户密码,其余的默认即可。下载完之后打开Stack Builder,连接自己的本机服务器

下一步,
,下载完之后安装,一定要选择你安装postgresql的文件夹,要不然报错。安装完之后psotgresql就配置好了。
LInux下安装,下面教程不详细,可以参照我的一篇文章
sudo apt-get install postgresql postgres-contrib
sudo su postgres
psql
\q
exit
sudo apt-get install postgis postgresql-9.6-postgis-2.3
安装postgis
sudo su postgres
psql
"CREATE EXTENSION postgis; CREATE EXTENSION postgis_topology" agricom
\q
exit
python manange.py runserver
ctrl +C退出
数据库配置完毕。
reporter app下的models.py
from django.contrib.gis.db import models#导入包
class Incidences(models.Models):
    name=models.CharField(max_length=20)
    # location=models.CharField(max_length=20) 
    location=models.PointField(srid=4326) #改这一行
    objects=models.GeoManager()#添这一行
    def __unicode__(self):
        return self.name
  class Meta:
        verbose_name_plural="Incidences"
        #更改localhost:8000/admin下的显示样式

在settings.py下INSTALL_APPS下添加如下代码

'django.contrib.gis',

在运行python manage.py makemigrations命令后出现缺少GDAL 类库的错误提示解决
下载GDAL,参考这篇文章里面的网址,下载对应的python版本和位数的gdal。
pip install GDAL-2.3.3-cp36-cp36m-win_amd64.whl
安装完成后,找到虚拟环境的存放的位置路径一般是这样的
%你的虚机环境%\Lib\site-packages\osgeo
在你的django项目中的settings.py添加如下代码:

GDAL_LIBRARY_PATH = r'你的虚拟环境路径\Lib\site-packages\osgeo\gdal203'
#gdal203是你在osgeo目录下看到的gdal203.dll,如果你的是202就写202。
GEOS_LIBRARY_PATH='你的虚拟环境路径\\Lib\\site-packages\\osgeo\\geos_c'
#同理这个也是你看到的是geos_c.dll

你的虚拟环境\Lib\site-packages\django\contrib\gis\gdal文件夹下找到libgdal.py文件,打开,添加如下代码,添加到lgdal = CDLL(lib_path)这句话前面

 BASE_WORKDIRECTORY = os.getcwd()
 os.chdir(os.path.dirname(lib_path))

第24行

# Windows NT shared libraries
    lib_names = ['gdal202', 'gdal201', 'gdal20', 'gdal111', 'gdal110', 'gdal19']

添加'gdal203',
添加后代码如下:

    # Windows NT shared libraries
    lib_names = ['gdal203','gdal202', 'gdal201', 'gdal20', 'gdal111', 'gdal110', 'gdal19']

同理osgeo也是这样添加的,在

_lgeos = CDLL(lib_path)

这句话前面加上下面这句话

 BASE_WORKDIRECTORY = os.getcwd()
 os.chdir(os.path.dirname(lib_path))

再次运行就ok了。


python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser

用户名
密码
python manage.py runserver
localhost:8000/admin
添加点
pip install django-leaflet
在settings.py下INSTALL_APPS下添加如下代码
'leaflet',
在reporter app下的admin.py添加如下代码

from leaflet.admin import LeafletAdmin
class IncidencesAdmin(LeafletGeoAdmin):
    pass
    #list_display=("name","location")
第三天

settings.py下最后追加如下代码

LEAFLET_CONFIG={
'DEFAULT_CENTER':(.023,36.87),#默认中心
'DEFAULT_ZOOM':5,
'MAX_ZOOM':20,
'MIN_ZOOM':3,
'SCALE':'imperial',#'both'
'ATTRIBUTION_PREFIX':'Inspired by Life in GIS',
}

第二天第三天视频

第四天

所需所有数据(提取码:vlqd)
把shp数据放到reporter app下的data文件夹下
gdal.org
ogrinspect
python manage.py ogrinspect reporter/data/counties.shp Countie --srid=4326 --mapping --multi
自动产生以下信息,windows下运行这句话有问题的话直接用这个信息即可。

# This is an auto-generated Django model module created by ogrinspect.
from django.contrib.gis.db import models


class Counties(models.Model):
    fips = models.CharField(max_length=2)
    iso2 = models.CharField(max_length=2)
    iso3 = models.CharField(max_length=3)
    un = models.IntegerField()
    name = models.CharField(max_length=50)
    area = models.IntegerField()
    pop2005 = models.BigIntegerField()
    region = models.IntegerField()
    subregion = models.IntegerField()
    lon = models.FloatField()
    lat = models.FloatField()
    geom = models.MultiPolygonField(srid=4326)


# Auto-generated `LayerMapping` dictionary for Countie model
counties_mapping = {
    'fips': 'FIPS',
    'iso2': 'ISO2',
    'iso3': 'ISO3',
    'un': 'UN',
    'name': 'NAME',
    'area': 'AREA',
    'pop2005': 'POP2005',
    'region': 'REGION',
    'subregion': 'SUBREGION',
    'lon': 'LON',
    'lat': 'LAT',
    'geom': 'MULTIPOLYGON',
}

把自动生成的class类代码复制到reporter app下的models.py
在后面追加一个函数

def __unicode__(self):
    return self.counties

把counties_mapping的内容保存到一盒新的文件里面名为load_layer.py,保存路径为reporter文件夹下
layerMapping,到django官网的文档产看
为load_layer.py添加引用

import os
from django.contrib.gis.utils import LayerMapping
from .models import Counties

添加如下代码:

county_shp=os.path.abspath(os.path.join(os.path.dirname(__file__),'data/counties.shp'))
def run(verbose=True):
  lm=LayerMapping(Counties,county_shp,counties_mapping,transform=False,encoding='UTF-8')
  lm.save(strict=True,verbose=verbose)

reporter app下的添加一个类

class CountiesAdmin(LeafletGeoAdmin):
    #list_display=('counties','codes')
    list_display=('name','pop2005')
admin.site.register(Counties,CountiesAdmin)

别忘了导入counties模型

python manage.py makemigrations
python manage.py migrate
python manage.py shell

>>>from reporter import load_layer
>>>load_layer.run()

python mange.py runserver
第五天

reporter app下的views.py

from django.views.generic import TemplateView
from django.core.serializers import serialize
from django.http import HttpResponse
from .models import Counties
class HomePage(TemplateView):
    template_name="index.html"
def county_datasets(request):
    counties=serialize('geojson',Counties.objects.all())
    return HttpResponse(counties,content_type='json')
reporter app下创建urls.py,添加如下代码:
from django.conf.url import include,url
from  .views import HomePage,county_datasets
urlpatterns=[
url(r"^$",HomePageView.as_view(),name='home'),
url(r"^county_data/$",county_datasets,name='country'),
url(r"^incidence/$",HomePageView.as_view(),name='home'),
]

agricom文件夹下的urls.py添加如下代码

from django.conf.url import include,url
# urlpatterns
url(r'^',include('reporter.urls')),

创建文件夹templates,在agricom文件夹下,
在这个文件夹下创建index.html,添加如下代码

<!doctype html>
<html>
{% load static %}
{% load leaflet_tags %}
<head>
<meta charset="UTF-8">
<title>主页</title>
{% leaflet_js %}
{% leaflet_css %}
<style>
#gis{
width:80%;
height:700px;
}
</style>
<script type="text/javascript" src="{% static 'dist/leaflet.ajax.js' %}"></script>
</head>
<body>
<h1>主页的内容</h1>
<br>
<script type="text/javascript">
function our_layers(map,options)
{
var datasets=new L.GeoJSON.AJAX("{% url 'country' %}",{
});
datasets.addTo(map);
}
</script>
{% leaflet_map 'gis' callback="window.our_layers" %}
</body>
</html>

在settings.py下的TEMPLATES添加如下代码:

'DIRS':[os.path.join(BASE_DIR,'templates')]

搜索leaflet ajax github
下载,解压
在agricom文件夹下创建static文件夹
把dist文件夹复制到static文件夹下,dist文件夹里面有两个js文件

在settings.py下添加如下语句:

STATICFILES_DIRS=(
os.path.join(BASE_DIR,'static')
)
第六天

Popups in Leaflet
reporter app下views.py添加如下代码

def incidences_datasets(request):
    incidences=serialize('geojson',Incidences.objects.all())
    return HttpResponse(incidences,content_type='json')
reporter app下urls.py添加如下代码
re_path(r"^incidence/$",incidences_datasets,name='incidences'),


index.html下的out_layers添加内容
var points=new L.GeoJSON.AJAX("{% url 'incidences'%}",{
onEachFeature:function(feature,layer){
    layer.bindPopup(feature.properties.name.toString())
    }
});
points.addTo(map);

修改如下内容:

var datasets=new L.GeoJSON.AJAX("{% url 'country' %}",{
onEachFeature:function(feature,layer){
   // layer.bindPopup(feature.properties.counties.toString()) }
 layer.bindPopup(feature.properties.name.toString()) }
});
第七天

index.html里面
在our_layers下的datasets下添加如下代码

style:function colors(feature) {
                switch(feature.properties.name){
                    case "China":
                        return{
                    color:"red",
                    fillOpacity:0.8
                    };
                    break;
                    case "Hong Kong":
                        return{
                    color:"green",
                    fillOpacity:0.8
                    } ;
                    break;
                }
            },
第八天

图层空间
搜索 leaflet grouplayercontrol
在static文件夹下创建一个新文件夹名为:layercontrol,在index.html文件夹下引用

<link  type="text/css" rel="stylesheet" href="{% static 'layercontrol/leaflet.groupedlayercontrol.css' %}"></script>
<script type="text/javascript" src="{% static 'layercontrol/leaflet.groupedlayercontrol.js' %}"></script>

下添加如下代码:

var groupedOverlays = {
  "Layers": {
    "Counties": datasets,
    "Incidences": points
  },
};
L.control.groupedLayers({}, groupedOverlays).addTo(map);
第九天

leafletJS官网
找到routing
打开这个网站http://www.liedman.net/leaflet-routing-machine/
看getting start
下载源码
在static文件夹下新建文件夹名字为:routing
将下载的文件里面的dist文件拷贝过去
添加script和link引用
添加如下代码

L.Routing.control({
  waypoints: [
    L.latLng(57.74, 11.94),
    L.latLng(57.6792, 11.949)
  ]
}).addTo(map);

添加到index.html里面去,添加到最后即可

题外话

python虚拟环境设置

pip install virtualenv
virtualenv venv #安装虚拟环境
#venv为虚拟环境目录名,目录名自定义
activate#开启虚拟环境,在虚拟环境的Scripts文件夹下运行
deactivate #停止虚拟环境,在虚拟环境的Scripts文件夹下运行

删除虚拟环境直接删除venv 文件夹即可

上一篇下一篇

猜你喜欢

热点阅读