栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

带有GeoAlchemy示例代码的烧瓶

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

带有GeoAlchemy示例代码的烧瓶

使用SQLAlchemy 0.8,Flask-SQLAlchemy和Geoalchemy 2:

from app import dbfrom geoalchemy2.types import Geometryclass Point(db.Model):    """represents an x/y coordinate location."""    __tablename__ = 'point'    id = db.Column(db.Integer, primary_key=True)    geom = db.Column(Geometry(geometry_type='POINT', srid=4326))

查询样例:

from geoalchemy2.elements import WKTElementfrom app import modelsdef get_nearest(lat, lon):    # find the nearest point to the input coordinates    # convert the input coordinates to a WKT point and query for nearest point    pt = WKTElement('POINT({0} {1})'.format(lon, lat), srid=4326)    return models.Point.query.order_by(models.Point.geom.distance_box(pt)).first()

将结果转换为x和y坐标的一种方法(转换为GeoJSON并提取坐标):

import geoalchemy2.functions as funcimport jsonfrom app import dbdef point_geom_to_xy(pt):    # extract x and y coordinates from a point geometry    geom_json = json.loads(db.session.scalar(func.ST_AsGeoJSON(pt.geom)))    return geom_json['coordinates']


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/647007.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号