解析ArcGis的字段计算器(一)——数值型数据计算,从“面积计算”开始.pdfVIP

解析ArcGis的字段计算器(一)——数值型数据计算,从“面积计算”开始.pdf

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

解析ArcGis的字段计算器(⼀)——数值型数据计算,从“⾯积

计算”开始

先来点⼉背景知识铺垫:

ArcMap的字段计算器提供了两种脚本语⾔的⽀持⽤以计算,两种脚本语⾔是VBScript与Python。

多数⼈选择使⽤前者,因为它的基本函数和Excel的函数貌似⼀样。注意我这⾥⽤了⼀个貌似“”,虽然Excel函数与VB函数有着千丝万缕的关系,但它

毕竟不是VB函数(ArcMap⾥⽤VBScript),把Excel函数照搬进ArcMap的计算器,许多是不可以运⾏的。使⽤VBScript函数正确的打开⽅式应该是

查询VBScript帮助。⾄于VB、VBA、VBScript啥关系,不讲。

在ArcMap的字段计算器⾥,VBScript语句中字段(Field)应该⽤“[field_Name]”的样式输⼊,Python语句中字段应该⽤“!field_Name!”的样式输⼊。

(提醒新来的“”,①不要把这玩意⼉“”抄过去,②所有符号应为英⽂的)。

Tip:数值型与字符串型拼接的常见错误

不论在VBScript还是Python,⾯积:+1.2这样的写法都是错误的。

+适⽤于字符串类型的连接,在VB中,字符串与数值连接可以使⽤;⽽在Python中,⾯积:+str(1.2)这样⼀个转换是必要的。

作者:yzhyingcool

ArcGis交流群:

Blog:

获取图斑(⾯要素)⾯积:

⾯积值是double型的,所以要放到Double型字段计算。

⽅法⼀:常⽤的,是在字段标题上右键——计算⼏何(CalculateGeometry)

⽅法⼆:使⽤Python语句的⽅式,在字段计算器中解析语⾔“”勾选Python,在语句块输⼊框填!shape.area!

⽅法⼆中使⽤Python语句,在ArcMap中要素的⼀些⼏何(Geometry)属性,可以通过“!shape.?!”的⽅式进⾏计算,这个我们以后继续分解。

有新来的“”可能会遇到⾯积不能计算的情况,这⼀般是因为数据的空间参考没有设置好,⾄于空间参考“”是神马玩意,不知道的请百度或者发红包给作

者,包教不会。

⾯积的单位转换(平⽅⽶转亩):直接[MJ]*0.0015

⾯积的舍⼊与取整:

1、舍⼊

⼀般我们会采⽤四舍五⼊的⽅式进⾏⼩数舍⼊,下⾯我们来贴图

VBScript,使⽤round([MJ],3)对⾯积字段的值取⼩数后3位,结果如图:

Python(ArcGis10.1使⽤Python2.7),使⽤round(!MJ!,3)对⾯积字段的值取⼩数后3位,结果就不贴图了,和上边⼀样。

有点意思吧?和你想的结果⼀样吗?⼀般使⽤中这样不会有问题,下⾯部分是闲扯扩展,有兴趣可读。

在编程语⾔中⼩数舍⼊⼀般采⽤“四舍六⼊五凑双”的⽅式,说的通俗点就是看舍⼊位数之后的数

距离哪个近就进位位给谁:

保留1位的话2.449是2.42.451是2.5

如果⼀样远(),那就凑双数:

5

如果取3位,第4位是末位值为5,进位后第3位不是双数就不进,所以2.2325是2.232,⽽2.2315也是2.232。

那么,怎么实现四舍五⼊呢?

①VBScript⽤FormatNumber([MJ],3)试试;

②Python⽤下⾯的函数试试:

defgetRound(val,n):

:function:替换内置round函数,实现保留n位⼩数的精确四舍五⼊

:paramval:类型string或数值型

:paramn:需要保留⼩数的位数,要求⼤于0

:return:四舍五⼊后的数据,类型string

n=int(n)

f={:.%sf}%n

returnf.format(round(float(val)*pow(10,n))/pow(10.0,n))

不知道怎么使⽤?给你个见下图

③确定没问题的⽅法——Excel函数处理后挂接回来。

2、取整

取整⼀般有两种,⼀种是直接取整数位,⼀种是舍⼊取整。

第⼀种在VBScript或者Python⾥都可以使⽤int函数实现

第⼆种使⽤round函数,这时候就有⽐较⼤的差距了。

题外话,再来点随机凑数

vb的随机数函数是rnd,它返回⼀个⼩于1,⼤于等于0的数

如果⽣成2-10之间的数,可以⽤rnd()*2+8

文档评论(0)

185****4509 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档