问题描述 ArcGIS 属性表属性中 中文内容显示为乱码
解决方法 可以cmd命令下建立键值
reg add HKEY_CURRENT_USER\Software\ESRI\Desktop10.3\Common\CodePage /v dbfDefault /t REG_SZ /d 936 /f原因分析 在 ArcGIS Desktop (ArcMap, ArcCatalog, and ArcToolbox) 中,有编码页转换功能(CODE PAGE CONVERSION),可以读写多种字符编码的 shapefile 和 dBASE 表。在系统注册表中,编码页转换功能(CODE PAGE CONVERSION)命名为 ‘dbfDefault’,可以修改这个值。
dbfDefault的作用写:
使用 ArcGIS for Desktop 打开 dBase 表文件时,程序先去读头文件中的 Language Driver ID (LDID) 或者是同名 *.CPG文件。前面二者都是用来在读文件之前,决定用什么编码类型来正确读出文件。如果有必要, ArcGIS for Desktop 会进行编码转换来显示字符串。
如果文件缺失 LDID 或者 .CPG 文件,编码就会被假定为 Windows (ANSI/Multi-byte)。也是因为这个原因,如果文件是 OEM 编码的,并且没有写入 LDID 或者 .CPG,字符就会出现乱码。 也就说 ArcGIS 把 OEM 文件当成 ANSI 文件来处理了。
多数情况下, shapefiles 和 dBASE 文件都会存储编码页信息。 但是有些程序的 OEM 文件没有包含编码页信息,例如 Microsoft Access 2000 and Excel 2000,所以这些文件读取时,就会乱码。为了避免这个问题,用户可以给没有编码页信息的文件设置 dbfDefault 。
在注册表中设置 ‘dbfDefault’ ,可以决定导出的 shapefile 和 dBASE 的编码类型。例如,把 ‘dbfDefault’ 设置为 OEM ,那么用 ArcMap, ArcCatalog, ArcToolbox 生成出来的 shapefile 和 dBASE 文件就是以 OEM编码的,设置成 ANSI ,那 shapefile 和 dBASE 文件就是 ANSI 编码的。
读:
读 shapefile 和 dBASE 文件的逻辑与写是相同的,如果缺失编码信息,ArcGIS 读取文件的编码类型由 dbfDefault 决定。
创建项 ‘Common’, 接着在其下创建 ‘CodePage’ 项, 添加 '字符串’,名称: dbfDefault,健值:oem(或者 936)
键值936代表是简体中文的意思。
资料:
【ArcGIS 10.3 属性表乱码问题】How To: Read and write shapefile and dBASE files encoded in various code pages
unicode, utf-8, codepage的含义 以及 相互关系
推荐阅读
- 开源|开源切片工具--TileStache
- GeoServer的安装与启动
- 影像分割|GlobeLand30及相关土地覆盖产品
- GEE学习及应用|GEE学习笔记04(参数类型)
- GDAL通过RasterIO读写图像文件,数据集的创建,图像相关信息的获取
- 百度,高德,google地图显示级别的比较
- ArcEngine 9.3 学习笔记(十一)(地图输出(Printer类,PageLayoutControl控件打印出图,栅格格式文件输出,矢量格式文件输出)...)
- GIS|将几种北京建成区数据下载裁剪重分类后以供比较
- GIS Lab9 栅格计算器,叠加