gdal mysql乱码_GDAL11.1读取shp数据中文乱码的解决方案

项目中有个shp有1W多数据,需要计算出每个斑块的面积,使用ESRI.ArcGIS.SpatialStatisticsTools.CalculateAreas出现如下C++调用错误

51d907fdd84fdfa61474ca6e4f6679b1.png

当然,这种错误不是我这种不会C++的能解决的。

后来使用了IArea接口遍历获取面积,速度太慢,被客户BS了。后来在一朋友建议下用gdal,效率妥妥的,1W+数据不到1秒就读完了。中间遇到了一个问题,使用了GDAL11.1版本,代码如下:

//注册所有格式

OSGeo.OGR.Ogr.RegisterAll();

// 支持中文路径

OSGeo.GDAL.Gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");

// 属性表字段支持中文

OSGeo.GDAL.Gdal.SetConfigOption("SHAPE_ENCODING", "");

OSGeo.GDAL.Gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");能读取到数据,但后面获取的字段值是乱码(一个黑色的菱形,里面一个?)...

OSGeo.GDAL.Gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");读出来的数据直接为空....

后面百度,bing,看到了这个大神的回答

http://ask.csdn.net/questions/168732

[DllImport("gdal111.dll", EntryPoint = "OGR_F_GetFieldAsString")]

public extern static System.IntPtr OGR_F_GetFieldAsString(HandleRef handle, int i);

这样暴力的能读取了,不过我在使用时候出现了另外一个错误:对 PInvoke 函数“xxxxx”的调用导致堆栈不对称。原因可能是托管的 PInvoke 签名与非托管的目标签名不匹配。请检查 PInvoke 签名的调用约定和参数与非托管的目标签名是否匹配。

解决方案如下,将上面的代码改为这样:

[DllImport("gdal111.dll", EntryPoint = "OGR_F_GetFieldAsString", CallingConvention = CallingConvention.Cdecl)]

public extern static System.IntPtr OGR_F_GetFieldAsString(HandleRef handle, int i);

后面调用就成功了,测试能正确的读取出中文属性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值