gdal mysql乱码_GDAL读取属性乱码的终极解决方案(C#)

本文提供了GDAL在C#中读取MySQL属性出现乱码的终极解决方案,通过设置GDAL配置选项并转换字段为字符串,避免了乱码问题。详细步骤包括设置"GDAL_FILENAME_IS_UTF8"和"SHAPE_ENCODING"选项,使用"OGR_F_GetFieldAsString"和"OGR_F_GetFieldAsBinary"函数,以及用系统默认编码转换字节数组为字符串。
摘要由CSDN通过智能技术生成

这里将告诉您GDAL读取属性乱码的终极解决方案(C#),具体完成步骤:

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

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

OSGeo.GDAL.Gdal.AllRegister();

OSGeo.OGR.Ogr.RegisterAll();

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

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

[DllImport("gdal300.dll", EntryPoint = "OGR_F_GetFieldAsBinary", CallingConvention = CallingConvention.Cdecl)]

public extern static System.IntPtr OGR_F_GetFieldAsBinary(HandleRef handle, int index, out int byteCount);

string fieldName = pFieldDefn.GetName();

int fieldIndex = pFeatureDefn.GetFieldIndex(fieldName);

//IntPtr pIntPtr = OGR_F_GetFieldAsString(OSGeo.OGR.Feature.getCPtr(pFeature), fieldIndex);

int byteCount =0;

//IntPtr a = count;

IntPtr pIntPtr = OGR_F_GetFieldAsBinary(OSGeo.OGR.Feature.getCPtr(pFeature), fieldIndex, out byteCount);

byte[] byteArray = new byte[byteCount];

Marshal.Copy(pIntPtr,byteArray, 0, byteCount);

Console.WriteLine(byteCount); // Marshal.PtrToStringAnsi(pIntPtr)

// Console.WriteLine(pFeature.GetFieldAsString(i));

string str = System.Text.Encoding.Default.GetString(byteArray);

// UTF8Encoding utf8 = new UTF8Encoding();// string str = utf8.GetString(byteArray);

Console.WriteLine(str);

-------------------------完--------------------------------GDAL读取属性乱码的终极解决方案(C#)就为您介绍到这里,感谢您关注懒咪学编程c.lanmit.com.

本文地址:https://c.lanmit.com/bianchengkaifa/net/5581.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值