解决python ogr shp字段写入中文乱码的问题
程序员文章站
2022-07-04 22:26:12
首先,先确认一下你的字段值是不是乱码,如果是,按照以下方法:
我的字段值是来自于一个geojson字符串,我在对它解析时做了如下处理:
properties =...
首先,先确认一下你的字段值是不是乱码,如果是,按照以下方法:
我的字段值是来自于一个geojson字符串,我在对它解析时做了如下处理:
properties = fea.get("properties") pro_json=json.dumps(properties) pro_json.replace('u\'','\'')#将unicode编码转化为中文先处理一下 pro_json=pro_json.decode("unicode-escape") #将unicode编码转化为中文 properties=json.loads(pro_json)
这样即可消除字段值中的中文乱码。
字段值没有乱码了,可是这样写入shp,shp中会出现乱码,使用如下方法解决:
首先,你需要用driver方法创建shp文件而不是直接用ogr.open:
driver=ogr.getdriverbyname("esri shapefile") ds =driver.createdatasource(shp_path)#打开要写入的数据源
然后,在driver创建之前加入如下两句:
gdal.setconfigoption("gdal_filename_is_utf8", "yes") gdal.setconfigoption("shape_encoding", "gbk")
成了。
源码如下:
def create_shp_with_geojson2(a,shp_path): gdal.setconfigoption("gdal_filename_is_utf8", "yes") gdal.setconfigoption("shape_encoding", "gbk") driver=ogr.getdriverbyname("esri shapefile") ds =driver.createdatasource(shp_path)#打开要写入的数据源 if ds is none: sys.exit('could not open this folder!') if ds.getlayer('test_polygon'): ds.deletelayer('test_polygon')#如果存在,就删除该数据 feature0=a['features'][0] geo = feature0.get("geometry") geo_type = geo.get('type')#获取图层类型 properties = feature0.get("properties") keys=properties.keys()#获取字段名称数组 if geo_type=='polygon' or 'multipolygon': ogr_type=ogr.wkbpolygon else: if geo_type=='point': ogr_type=ogr.wkbpoint else: if geo_type=='linestring' or 'multilinestring': ogr_type=ogr.wkblinestring out_lyr=ds.createlayer('test_polygon',none,ogr_type)#创建图层 #接下来往图层中写入feature for key in keys: field_testfield = ogr.fielddefn(key, ogr.oftstring)#创建字段 field_testfield.setwidth(254) out_lyr.createfield(field_testfield) for fea in a['features']: geometry_json=fea.get("geometry") properties = fea.get("properties") pro_json=json.dumps(properties) pro_json.replace('u\'','\'')#将unicode编码转化为中文先处理一下 pro_json=pro_json.decode("unicode-escape") #将unicode编码转化为中文 properties=json.loads(pro_json) geom=ogr.creategeometryfromjson(str(geometry_json)) out_defn=out_lyr.getlayerdefn() out_feat=ogr.feature(out_defn) out_feat.setgeometry(geom)#创建geometry for i in range(len(keys)): value=properties.get(keys[i])#获取属性值 print(value) out_feat.setfield(i,value) out_lyr.createfeature(out_feat)#在图层中插入该要素 if __name__ == '__main__': create_shp_with_geojson2(a,'web')
以上这篇解决python ogr shp字段写入中文乱码的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: Freefilesync-文件夹自动同步
下一篇: 为什么要写博客?
推荐阅读
-
解决vscode python print 输出窗口中文乱码的问题
-
解决Python2.7读写文件中的中文乱码问题
-
python 采集中文乱码问题的完美解决方法
-
python 采集中文乱码问题的完美解决方法
-
解决python中画图时x,y轴名称出现中文乱码的问题
-
解决python2 绘图title,xlabel,ylabel出现中文乱码的问题
-
在arcgis使用python脚本进行字段计算时是如何解决中文问题的
-
在arcgis使用python脚本进行字段计算时是如何解决中文问题的
-
解决python中画图时x,y轴名称出现中文乱码的问题
-
解决python2 绘图title,xlabel,ylabel出现中文乱码的问题