扣丁学堂Python培训简述如何解决Python ogr shp字段写入中文乱码的问题

ITxuexi_66 · · 1723 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

本篇文章Python培训小编给大家分享一下如何解决Python ogr shp字段写入中文乱码的问题,文中有代码列出供小伙伴们参考,对Python开发感兴趣的小伙伴就随小编来了解一下吧。 首先,先确认一下你的字段值是不是乱码,如果是,按照以下方法: 我的字段值是来自于一个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和人工智能方面内容的小伙伴,请关注扣丁学堂Python培训官网、微信等平台,扣丁学堂IT职业在线学习教育平台为您提供权威的Python开发环境搭建视频,Python培训后的前景无限,行业薪资和未来的发展会越来越好的,扣丁学堂老师精心推出的Python视频教程定能让你快速掌握Python从入门到精通开发实战技能。

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1723 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传