在arcgis使用python脚本进行字段计算时是如何解决中文问题的
2015-10-18 15:03
1016 查看
在arcgis打开一个图层的属性表,可以对属性表的某个字段进行计算,但是在平常一般都是使用arcgis提供的字段计算器的界面进行傻瓜式的简答的赋值操作,并没有使用到脚本对字段值进行逻辑的操作。由于最近一直在学python脚本,刚好又碰上一好基友需要我的助攻(使用arcgis制图),这就用上了。本以为能够轻松搞定的,没想到搬石头砸脚了,下面就来说我是如何被砸脚的吧。
二、问题描述:将test字段中值为“湖南”的变为“湖南省”。
这个逻辑是相当的简单,使用python写一个对应的方法为:
def cal(value): if(value=='湖南'): return value + '省' else: return value
在arcgis中运行python代码如下图:
注意:引用属性字段的值得方法为!test!
点击确定,结果弹出一个错误,没有提示具体是什么错误,最后在查找了一下资料,原来是python使用中文的时候一定要进行转码。
三、解决方案
于是将上面代码中有中文出现的地方对其进行转码就好了。更改后的代码如下:
def cal(value): if(value=='湖南'.decode('utf-8')): return value + '省'.decode('utf-8') else: return value
这下就没有错误了,需要更改的就是在字符串”湖南“和‘省”后面添加 decode('utf-8')方法对其进行编码。
这下就解决了在arcgis中python脚本处理中文的问题。
四、小结
在arcgis中使用python脚本,只要碰到中文就需要对其进行decode('utf-8')进行转码。
另外,在arcgis中提供的python脚本编辑器超级难用,所以可以先使用好用的python编辑,将逻辑代码编写好,然后复制进去,然后运行,又快又好。
您可能感兴趣的文章:
相关文章推荐
- DB2获取当前用户表、字段、索引等详细信息
- MySQL字段自增自减的SQL语句示例介绍
- SQL SERVER使用REPLACE将某一列字段中的某个值替换为其他的值
- access的备注字段限制64K
- 一句sql更新两个表并可更新对应的字段值具体实现
- vbs生成ACCESS数据里所有表的字段
- 在oracle数据库里创建自增ID字段的步骤
- 列出SQL Server中具有默认值的所有字段的语句
- PHP以指定字段为索引返回数据库所取的数据数组
- MongoDB查询操作限制返回字段的方法
- C#三种判断数据库中取出的字段值是否为空(NULL) 的方法
- 基于Arcgis for javascript实现百度地图ABCD marker的效果
- 批量替换 MySQL 指定字段中的字符串
- mysql中如何判断当前是字符 mysql判断字段中有无汉字
- oracle 实际值超过数据库某个字段指定长度报错解决
- oracle获取当前用户表、字段等详细信息SQL
- Oracle 查询表信息获取表字段及字段注释
- php使用sql数据库 获取字段问题介绍
- MySql表、字段、库的字符集修改及查看方法
- Mysql字符串字段判断是否包含某个字符串的2种方法