ArcGIS字段计算器(Python篇) —— 群内问题汇总

        博客开张,多多捧场。再给咱交流群打个广告。(全国最大ARCGIS技术交流QQ群:arcgis技术交流 47410747)
    
        本博客全为原创,转载请注明蓝胖子。他人东西(云)笔记即可,不用记录在博客。
    

        作为近年Esri支持得最好的脚本语言,Python能够在字段计算器中解决不少简单的属性问题(如编号、截位等)。ArcPy则是直接能够进行ArcGis二次开发。系统性文章目标太大,目前我会把群里面之前问的字段计算器问题以及ArcPy问题汇总。有字段计算器问题的兄弟们可以在群里面找蓝胖子,也可以找其他人员。解决了再到本帖汇总。


        另注:python是对代码缩进要求很严格的编程语言。本博客统一采用4个空格作为缩进。

        python很少使用分号,逗号一定使用英文半角。(同学们请注意)


        问题一:多字段的最大、最小值

        python的基础函数中有求数值的求和、最大、最小值函数,所以我们也可以直接使用的。

        举例:假设有三个字段,NumA,NumB,NumC三个字段都是数值型的字段,我们需要求三个字段的最大值,并写入到MaxNum字段中。

        只需在表达式中输入 max([NumA,NumB,NumC])即可。

        最大值函数:max([NumA,NumB,NumC])

        最小值函数:min([NumA,NumB,NumC])

        多字段求和函数:sum([NumA,NumB,NumC])


        最大值使用截图如下:

    


        问题二:流水号编码

        

        举例1:

        举例描述:已有宗地图层,包含字段“地籍子区”、“特征码”、“宗地编码”按照 宗地统一编码 规则给图层内的宗地编码。
        宗地统一编码规则:宗地编码 = “地籍子区” + “特征码” + 5位自然数流水号。
    

        原始属性表截图:

        字段计算器使用截图:


        处理结果截图:

        代码块如下:

dict={}
def funZdbm(fldVal,tzm):
    if fldVal == None:
        return None
    if tzm == None:
        return None
    temp = 0
    key = fldVal + tzm
    if dict.has_key(key) == True:
        temp = dict[key]
        strVal = key + str(temp+1).zfill(5)
        dict[key] = temp+1
        return strVal
    else :
        dict[key] = 1
        strVal = key + str(temp+1).zfill(5)
        return strVal

        举例2:

        描述:有文本型字段流水号,其中有两行记录已编号,需要续编其他记录,并在前面补零。保证流水号为6位数


        原始属性表截图:

字段计算器使用截图:

处理结果截图:

 代码块:

max = 504
def funLsh(fldVal): 
    global max
    fldVal = fldVal.strip()
    if fldVal == None or fldVal == "":
        max = max + 1
        return str(max).zfill(6)
    else:
        return fldVal


        问题三:文本型字段查重

        描述: 检查宗地图层,将“宗地代码”字段有重复记录的内容标记出来,并将检查结果赋给”检查结果”字段。

    

        原始属性表截图:

        字段计算器使用截图:


        处理结果截图:

        代码块:(此代码在数据量太大的情况下慎用,估计会比较卡,预计十万以内还是可以承受,有异常可留言博主)

dict={}
def adjRepeat(fldVal,id):
    if fldVal == None:
        return None
    temp = 0
    strVal = ""
    if dict.has_key(fldVal) == True:
        temp = dict[fldVal]
        strVal = "宗地代码字段和FID为" + str(temp) + "的图元重复"
        return strVal
    else :
        dict[fldVal] = id
        return ""


转载自:https://blog.csdn.net/chinagj07/article/details/53740706

You may also like...