本文主要是介绍Python使用psycopg2读取PostgreSQL的geometry字段出现二进制乱码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1、问题
读取geometry字段出现二进制乱码
查询语句:
sql = "select * from public"
Note:
这种写法在PostgreSQL中直接查询, 没有问题,不会报错。
但是在Python中查询,如果导出的geom还是一长串的geometry 格式的话, POINT、LineString等矢量数据会显示为二进制或者字符串。
2 解决办法
如果想要达到MySQL中的查询效果,需要对POINT等矢量数据加上ST_ASTEXT:将几何数据转换成可读的文本类型。得到的是有多个经纬度的,是POLYGON。正确的查询语句:
sql = "select st_astext(geom) from public"
3 插入geometry字段
想要把ST_ASTEXT读出来的数据又存回到数据库表的geometry数据类型的字段时,我们需要使用ST_GeomFromText,:根据字符串构建几何。
sql = """INSERT INTO lane(lane_id, link_id, phase_id, width, length, max_speed, geom) VALUES (%s, %s, %s, %s, %s, %s, ST_GeomFromText(%s))"""my_pg.sql_insert(sql, lane)
这篇关于Python使用psycopg2读取PostgreSQL的geometry字段出现二进制乱码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!