(十九)arcpy开发&利用arcpy实现在arcgis中对某字段值非指定值统计验证

本次我们学习的是关于如何利用arcpy实现,给定一个字段名,和一些给定关于该字段名一些具体值。然后统计关于该字段名中不是在给定具体值中其他列值。具体来说就是,我们现在有一个字段名GBCODE,然后里面有很多值,你比如说61030,61031,61032、61033,61034等等,而现在呢,我们需要统计除了61030,61031,61032其他值的数目。那么如和实现呢,首先我们需要验证一些输入的字段名是否在我们给定的shapefile文件中,然后统计给定的shapefile所有列名称,然后使用遍历所有的数据行,然后统计出所有的不是在给定的值,即可。

#coding=utf-8
import os
import arcpy
import sys


def getFieldNames(fc):
    fieldList = []
    for f in arcpy.ListFields(fc):
        fieldList.append(str(f.name))
    return fieldList

def getCount( fc):
    r = arcpy.GetCount_management(fc)
    return int(r.getOutput(0))
def validateField(fc, colName, valueList):
    print("\n验证要素类 %s..." % os.path.basename(fc))
    rowCount = getCount(fc)
    print("需要验证 %s 个字段值 根据字段 %s..." % (rowCount, colName))
    fields=getFieldNames(fc)
    if not colName in getFieldNames(fc):
        print("列名 %s 没有找到!" % colName)
        return ("列没有找到", None, None)
    rowCount = getCount(fc)
    processedCount = 0
    badRows = 0
    badRowList = []
    badValueList = []
    badValueIndex = {}
    OIDField = arcpy.Describe(fc).OIDFieldName
    with arcpy.da.SearchCursor(fc, [colName, OIDField]) as c:
        for row in c:
            processedCount += 1
            badVal = row[0]
            badRowOID = row[1]
            if not badVal in valueList:
                badRows += 1
                badRowList.append(badRowOID)
                badValueList.append(badVal)
                if badVal in list(badValueIndex.keys()):
                    badValueIndex[badVal].append(badRowOID)
                else:
                    badValueIndex[badVal] = [badRowOID]
        sys.stdout.write('\r')
        print("OK rows: %s. Bad rows: %s. (%s%s)" % (
            processedCount - badRows, badRows, round(((processedCount / rowCount) * 100), 1), '%'),)
    print("\n完成字段值的验证 %s. %s 个列值是没有在给定数据里" % (colName, badRows))
    if badRows > 0:
        print("警告: %s 个非法列值关于 %s.字段值" % (badRows, colName))
        return (badRowList, badValueList, badValueIndex)
    else:
        return (None, None, None)

data="D:\\Data\\中国国界和省界的SHP格式数据\\省界\\bou2_4l.shp";
validateField(data,'GBCODE',[61030,61031,61032]);

最后的统计结果如下图所示。

 

 


                                                                更多内容,请关注公众号

                                                       

### 回答1: 要使用 Python 在 ArcGIS 指定图层实现增加多个指定字段,可以使用 `AddField_management` 工具。该工具用于向指定的要素类或表添加新字段。 以下是一个示例代码,可以向名为 `my_layer` 的图层添加名为 `field1`、`field2` 和 `field3` 的三个新字段: ```python import arcpy # 设置工作空间 arcpy.env.workspace = "C:/data" # 要添加字段的图层名称 layer_name = "my_layer" # 添加字段列表 field_list = ["field1", "field2", "field3"] # 循环遍历字段列表,并向图层添加每个字段 for field in field_list: arcpy.AddField_management(layer_name, field, "TEXT", "", "", 50) ``` 在上面的代码,首先将工作空间设置为数据所在的文件夹。然后,定义了要添加字段的图层名称和一个包含要添加的字段名称的列表。最后,使用 `AddField_management` 工具的 `for` 循环遍历列表,并向图层添加每个字段。在此示例,所有新字段的数据类型都设置为“文本”,并且字符长度为50。根据需要,可以调整这些参数。 注意,为了使用此代码,需要安装并配置 ArcPy 模块,并且必须具有适当的 ArcGIS 许可证。 ### 回答2: 要在ArcGIS使用Python对指定图层实现增加多个指定字段,可以使用arcpy模块和相应的函数。以下是一个简单的代码示例: ```python import arcpy # 设置工作空间 workspace = r"C:\path\to\your\workspace.gdb" arcpy.env.workspace = workspace # 指定要操作的图层和要添加的字段 layer_name = "your_layer" field_names = ["field1", "field2", "field3"] # 检查图层是否存在 if arcpy.Exists(layer_name): # 使用ListFields函数查看当前图层的字段 fields = arcpy.ListFields(layer_name) # 检查要添加的字段是否已经存在于图层 existing_fields = [field.name for field in fields] new_fields = [field_name for field_name in field_names if field_name not in existing_fields] if new_fields: # 使用AddField函数逐个在图层添加新字段 for new_field in new_fields: arcpy.AddField_management(layer_name, new_field, "TEXT", field_length=50) print("字段添加成功。") else: print("所有要添加的字段已经存在于图层。") else: print("指定的图层不存在。请检查图层名称和工作空间路径是否正确。") ``` 以上代码首先设置了工作空间,然后指定了要操作的图层名称和要添加的字段列表。 然后,代码检查指定的图层是否存在,并使用ListFields函数获得当前图层的所有字段。 接着,代码检查要添加的字段是否已经存在于图层,将不存在的字段加入到一个新列表。 最后,代码使用AddField函数逐个在图层添加新字段字段类型设置为“TEXT”,字段长度设置为50。 如果所有要添加的字段都已经存在于图层,则输出提示信息。 如果指定的图层不存在,则输出错误信息。 请注意,在运行代码之前,请将示例的工作空间路径、图层名称和字段列表更改为您实际的路径和名称。此外,还可以根据需要修改字段类型和长度。 ### 回答3: 在ArcGIS,可以使用Python的ArcPy模块来实现指定图层增加多个指定字段的操作。下面是一个示例代码: ```python import arcpy # 指定要添加字段的图层路径 layer_path = r"C:\path\to\your\layer.shp" # 指定要添加的字段列表 fields = [ {'name': 'field1', 'type': 'TEXT'}, {'name': 'field2', 'type': 'DOUBLE'}, {'name': 'field3', 'type': 'LONG'} ] # 打开编辑会话 with arcpy.da.Editor(arcpy.env.workspace) as edit_session: # 打开图层 with arcpy.da.UpdateCursor(layer_path, ['shape@']) as cursor: # 在每个要素上迭代 for row in cursor: # 获取要素的几何信息 geometry = row[0] # 创建一个新的要素对象,并将几何信息赋给新要素 new_feature = arcpy.Feature() # 将新要素添加到图层 cursor.insertRow([new_feature]) # 在图层添加指定字段 arcpy.management.AddFields(layer_path, fields) print("字段添加完成。") ``` 以上代码首先指定了要添加字段的图层路径和要添加的字段列表。然后,在编辑会话打开图层,并在每个要素上迭代,创建一个新的要素对象,并将其添加到图层。最后,使用`arcpy.management.AddFields()`函数在图层添加指定字段
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yGIS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值