Это очень простая задача, но я не могу понять правильный синтаксис.
У меня есть шейп-файл, атрибуты которого похожи на следующие:
FID Shape FIELD1 FIELD2 FIELD3 ...
0 Polygon 0 1 0
1 Polygon 3 0 7
2 Polygon 3 4 7
...
Количество полей и их имена всегда разные.
Мне нужно создать новое поле (назовем его NUM) и посчитать количество нулей в каждой строке.
Пример вывода:
FID Shape FIELD1 FIELD2 FIELD3 NUM
0 Polygon 0 1 0 2
1 Polygon 3 0 7 1
2 Polygon 3 4 7 0
Я знаю, как создать новое поле, однако мне неясно, что делать дальше.
Рабочий код:
#path is path to shape file
def a(path):
fields = arcpy.ListFields(path,"FID_*") #FID_* is wildcard to select a fields name
arcpy.AddField_management(path, "NUM", "SHORT") #create a field with name NUM
cursor= arcpy.UpdateCursor(path)
for row in cursor:
count=0
for field in fields:
a= row.getValue(field.name) #take a value
if a==0: #if value=0 then value=value+1
count+=1
row.setValue("NUM", count)
cursor.updateRow(row)
del row
del cursor
Спасибо, blah238 , теперь я могу есть питонов!
источник