geopandas 导出shp文件的一种方法,解决报编码错误(中文列名的情况下)

本文主要是介绍geopandas 导出shp文件的一种方法,解决报编码错误(中文列名的情况下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 解决问题:

geopandas 导出shp文件报编码错误(中文标题的情况下),改成utf-8和gbk都不行,取代用pyhsp导出

 

使用方法:一共三步

第1步:导入包

import geopandas as gpd
import shapefile
from itertools import chain
from osgeo import osr

第2步:导入数据

city_map = gpd.read_file('d:/city.shp') #或者tab,geojson或者自己生成的gdf都可以

第3步:导出shp,不报编码错误

# 使用下面代码中的to_shp函数

to_shp(city_map ,
            out_path='d:/city_new.shp',
            encoding='gbk',
            geometry_name='geometry')

完成

 

 

import geopandas as gpd
import shapefile
from itertools import chain
from osgeo import osrdef to_shp(self,gdf_data,out_path='d:/polygon.shp',encoding='gbk',geometry_name='geometry'):'''功能:将geopandas导入的gdf导出为shp格式文件,目前支持polygon,MultiPolygon,BaseMultipartGeometryPoint,MultiPoint,LineString,LinearRing,MultiLineString不支持 GeometryCollection主要解决geopandas导出shp文件中文乱码问题'''#将‘geometry’列放到最后gdf_data = gdf_data.reindex(columns=(gdf_data.columns.drop(geometry_name).insert(gdf_data.shape[1],geometry_name)))gdf_data = gpd.GeoDataFrame(gdf_data,crs="epsg:4326",geometry=geometry_name)w = shapefile.Writer(out_path,encoding='gbk')#列名传给shp的属性列名[w.field(x) for x in gdf_data.drop(columns=geometry_name).columns]#循环每一行数据判断类型整理成对应的列表写入wfor row in gdf_data.iterrows():geo = row[1]['geometry']if geo.type == 'MultiPolygon':#判断是否为MultiPolygon是就循环下exterior_z = []for data in geo:data_a = data.exteriorexterior_z.append([[list(x) for x in list(data_a.coords)]])for data_i in data.interiors:exterior_z.append([[list(x) for x in list(data_i.coords)]])exterior = list(chain(*exterior_z))w.poly(exterior)elif geo.type == 'Polygon':def to_co(ring):return [[list(x) for x in list(ring.coords)]]exterior = list(chain.from_iterable(map(to_co,[geo.exterior, *geo.interiors])))w.poly(exterior)elif geo.type == 'Point':exterior = (geo.x, geo.y)w.point(exterior)elif geo.type == 'MultiPoint':exterior = list(map(lambda x:[x.x,x.y],geo))w.multipoint(exterior)elif geo.type == 'LineString':exterior = [[list(x) for x in list(geo.coords)]]w.line(exterior)elif geo.type == 'LinearRing':exterior = [[list(x) for x in list(geo.coords[:-1])]]w.line(exterior)elif geo.type == 'MultiLineString':exterior = [[list(x) for x in list(x.coords)] for x in geo]w.linem(exterior)else:print('错误一行')print(geo.type)w.record(*[x for x in row[1][:-1]]) # 输出每一行的内容除了geometryw.close()# 设置投影,通过.prj文件设置,需要写入一个wkt字符串##gdal的GetProjection()返回的是wkt字符串,需要ImportFromWkt#projstr="""PROJCS["WGS_1984_UTM_zone_50N",proj = osr.SpatialReference()proj.ImportFromEPSG(4326)#或 proj.ImportFromProj4(proj4str)等其他的来源wkt = proj.ExportToWkt()#写出prj文件f = open(out_path.replace(".shp",".prj"), 'w')f.write('GEOGCS["GCS_WGS_1984",DATUM["D_WGS_1984",SPHEROID["WGS_1984",6378137.0,298.257223563]],PRIMEM["Greenwich",0.0],UNIT["Degree",0.0174532925199433]]')f.close()

 

这篇关于geopandas 导出shp文件的一种方法,解决报编码错误(中文列名的情况下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1025423

相关文章

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

Oracle 通过 ROWID 批量更新表的方法

《Oracle通过ROWID批量更新表的方法》在Oracle数据库中,使用ROWID进行批量更新是一种高效的更新方法,因为它直接定位到物理行位置,避免了通过索引查找的开销,下面给大家介绍Orac... 目录oracle 通过 ROWID 批量更新表ROWID 基本概念性能优化建议性能UoTrFPH优化建议注

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

Pandas进行周期与时间戳转换的方法

《Pandas进行周期与时间戳转换的方法》本教程将深入讲解如何在pandas中使用to_period()和to_timestamp()方法,完成时间戳与周期之间的转换,并结合实际应用场景展示这些方法的... 目录to_period() 时间戳转周期基本操作应用示例to_timestamp() 周期转时间戳基

在 PyQt 加载 UI 三种常见方法

《在PyQt加载UI三种常见方法》在PyQt中,加载UI文件通常指的是使用QtDesigner设计的.ui文件,并将其转换为Python代码,以便在PyQt应用程序中使用,这篇文章给大家介绍在... 目录方法一:使用 uic 模块动态加载 (不推荐用于大型项目)方法二:将 UI 文件编译为 python 模

Nginx 访问 /root/下 403 Forbidden问题解决

《Nginx访问/root/下403Forbidden问题解决》在使用Nginx作为Web服务器时,可能会遇到403Forbidden错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录解决 Nginx 访问 /root/test/1.html 403 Forbidden 问题问题复现Ng

Python将字库文件打包成可执行文件的常见方法

《Python将字库文件打包成可执行文件的常见方法》在Python打包时,如果你想将字库文件一起打包成一个可执行文件,有几种常见的方法,具体取决于你使用的打包工具,下面就跟随小编一起了解下具体的实现方... 目录使用 PyInstaller基本方法 - 使用 --add-data 参数使用 spec 文件(

Python的pip在命令行无法使用问题的解决方法

《Python的pip在命令行无法使用问题的解决方法》PIP是通用的Python包管理工具,提供了对Python包的查找、下载、安装、卸载、更新等功能,安装诸如Pygame、Pymysql等Pyt... 目录前言一. pip是什么?二. 为什么无法使用?1. 当我们在命令行输入指令并回车时,一般主要是出现以

Python解决雅努斯问题实例方案详解

《Python解决雅努斯问题实例方案详解》:本文主要介绍Python解决雅努斯问题实例方案,雅努斯问题是指AI生成的3D对象在不同视角下出现不一致性的问题,即从不同角度看物体时,物体的形状会出现不... 目录一、雅努斯简介二、雅努斯问题三、示例代码四、解决方案五、完整解决方案一、雅努斯简介雅努斯(Janu

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格