在开发环境下,首先对esri进行初始化,初始化如果用LicenseControl的话,字段中含有汉字时可以正常使用,当使用LicenseInitializer强制进行初始化时,读取含有汉字的字段时,就会出现乱码。
乱码是由于编码引起的,Google之后,在国外的网站查到DBF的编码格式为固定的ISO8559-1,所以需要做的事是将ISO8559-1的编码转化为gb2312,经测试与arcgis版本无关,10.x版本都可完美解决中文乱码问题,代码如下:
// 写入字段值
while (pFeature != null)
{
DataRow dataRow = dataTable.NewRow();
for (int i = 0; i < fieldCount; i++)
{
byte[] temp = Encoding.GetEncoding("ISO8859-1").GetBytes(pFeature.get_Value(i).ToString());
dataRow[i] = Encoding.Default.GetString(temp);
}
dataTable.Rows.Add(dataRow);
pFeature = pFeatureCursor.NextFeature();
}
引用:
原文链接:https://blog.youkuaiyun.com/kolacowboy/article/details/9014717ArcEngine读取ShapeFile时,出现乱码的解决方案_10.1 arcobject生成shp字段名称乱码-优快云博客https://blog.youkuaiyun.com/kolacowboy/article/details/9014717