Ввод значений с клавиатуры – не единственный способ редактирования значений в таблице. Вам может потребоваться выполнить математические вычисления над группой значений поля для отдельной записи или даже для всех записей. Можно выполнять как простые, так и сложные вычисления над всеми либо только выбранными записями. Кроме того, в полях атрибутивных таблиц можно вычислить длину, периметр и прочие геометрические свойства. В разделах ниже приводятся примеры использования калькулятора поля. Вычисления выполняются с помощью Python, SQL и Arcade.
Этот раздел описывает примеры скриптов на основе Python для Вычислить поле. Более подробно о выражениях Arcade см. руководство по ArcGIS Arcade. Более подробно о выражениях SQL см. в разделе Вычислить значения полей.
Примечание:
- Python требует структурированное расположение текста в синтаксисе. Для определения каждого логического уровня используются от двух до четырех пробелов. Приводите в соответствие начало и конец каждого блока, и будьте последовательны.
- Поля выражений вычислений Python заключаются в восклицательные знаки (!!).
- При наименовании переменных следует помнить, что Python чувствителен к регистру, поэтому имя value не равнозначно имени Value.
- Завершив ввод, можно нажать кнопку Экспорт  , если вы хотите записать введенные данные в файл. С помощью кнопки Импорт , если вы хотите записать введенные данные в файл. С помощью кнопки Импорт вы сможете найти и выбрать из имеющихся файл с выражением для вычисления. вы сможете найти и выбрать из имеющихся файл с выражением для вычисления.
Простые вычисления
Ряд вычислений можно производить, используя только короткое выражение.
Примеры простых строчек
Строки поддерживают несколько строковых функций Python, в том числе capitalize, rstrip и replace.
Сделать заглавной первую букву текста в поле CITY_NAME.
!CITY_NAME!.capitalize()Убрать все пробелы на концах строчек в поле CITY_NAME.
!CITY_NAME!.rstrip()Заменить все случаи "california" на "California" в поле STATE_NAME.
!STATE_NAME!.replace("california", "California")Доступ к символам в текстовом поле осуществляется путем индексации и разделения в Python. Индексация возвращает символы в индексном местоположении; разделение – группу символов. В следующей таблице примите !fieldname! как строковое поле со значением "abcde".
| Пример | Объяснение | Результат | 
|---|---|---|
| !fieldname![0] | Первый символ | "a" | 
| !fieldname![-2] | Второй символ с конца | "d" | 
| !fieldname![1:4] | Второй, третий и четвертый символы | "bcd" | 
Python также поддерживает форматирование строк с использованием метода format().
Скомбинировать поля FieldA и FieldB, разделенные двоеточием.
"{}:{}".format(!FieldA!, !FieldB!)Простые математические примеры
Python предоставляет инструменты для обработки чисел. Python также поддерживает ряд числовых и математических функций, в том числе math, cmath, decimal, random, itertools, functools и operator.
| Оператор | Объяснение | Пример | Результат | 
|---|---|---|---|
| x + y | x плюс y | 1,5 + 2,5 | 4.0 | 
| x – y | x минус y | 3,3 – 2,2 | 1.1 | 
| x * y | x умножить на y | 2,0 * 2,2 | 4.4 | 
| x / y | x разделить на y | 4,0 / 1,25 | 3.2 | 
| x // y | x разделить на y (с округлением) | 4.0 // 1.25 | 3.0 | 
| x % y | x по модулю y | 8 % 3 | 2 | 
| -x | отрицательное выражение от x | x = 5 -x | -5 | 
| +x | x остается без изменений | x = 5 +x | 5 | 
| x ** y | x возвести в степень y | 2 ** 3 | 8 | 
Умножить
!Rank! * 2Вычислить объем сферы по заданному полю с радиусами.
4.0 / 3.0 * math.pi * !Radius! ** 3Примечание:
Поля Short, Long и Big Integer различаются следующими диапазонами целых чисел, которые они поддерживают:
- Short (16-битное целое)—Поддерживает целые числа от -(215) до 215 (-32,768 и 32,767)
- Long (32-битное целое)—Поддерживает целые числа от -(231) до 231 (-2,147,483,648 и 2,147,483,647)
- Big Integer (64-битное целое)—Поддерживает целые числа от -(253) до 253 (-9,007,199,254,740,992 и 9,007,199,254,740,991)
Прежние версии:
В ArcGIS AllSource используется Python 3, а в ArcGIS Desktop используется Python 2. В Python 2 используются математические целые числа, то есть деление двух целочисленных значений всегда дает в результате целочисленное значение (3 / 2 = 1). В Python 3 при делении целочисленных значений результат будет числом с плавающей точкой (3 / 2 = 1.5).
Встроенные функции Python
Python содержит ряд встроенных функций, включая max, min, round и sum.
Вычисление максимального значения для каждой записи в списке полей.
max([!field1!, !field2!, !field3!])Вычисление суммы для каждой записи в списке полей.
sum([!field1!, !field2!, !field3!])Использовать блоки кода
С помощью выражений Python и параметра Блок кода вы можете сделать следующее:
- Использовать в выражении любые функции Python.
- Получать доступ к функциям и объектам геообработки.
- Получать доступ к свойствам геометрии
- Получать доступ к новому оператору случайных значений.
- Переклассифицировать значения с использованием логики if-then-else.
| Тип выражения | Блок кода | 
|---|---|
| Python (ключевое слово PYTHON3) | Поддерживается функционал Python. Блок кода определяется посредством функций Python (def). Свойства геометрии выражаются с помощью объектов геообработки, например точечные объекты, если это необходимо. | 
| Arcade | Поддерживается функциональность Arcade. | 
| SQL | Поддерживает выражения SQL. Выражения SQL применяются для улучшения поддержки вычислений в сервисах объектов и в многопользовательских базах геоданных, в частности для повышения производительности. Вместо того чтобы выполнять вычисления для одного объекта или строки одновременно, один запрос отправляется к базе данных или сервису объектов. | 
Прежние версии:
В ArcGIS Desktop инструмент Вычислить поле поддерживает типы выражений VB, PYTHON и PYTHON_9.3. Тип выражения VB, поддерживаемый в некоторых продуктах, не поддерживается в 64-битных продуктах, и в том числе в ArcGIS AllSource.
Ключевые слова PYTHON и PYTHON_9.3 все еще поддерживаются в ArcGIS AllSource для сохранения обратной совместимости, но не указываются в списке выбора. Скрипты Python, использующие ключевые слова, продолжат работать корректно.
Единственное различие между выражениемPYTHON3 и предшествующим ключевым словом PYTHON_9.3 заключается в том, что PYTHON3 возвращает значения в полях данных как объекты Python datetime.
Примечание:
Тип выражения PYTHON3 не связан с версией Python, установленной с ArcGIS AllSource. Это просто третье исторически связанное с Python ключевое слово (после скрытых сейчас PYTHON и PYTHON_9.3).
Функции Python задаются с помощью ключевого слова def, за которым идет имя функции и ее входные параметры. Можно написать функцию Python, которая будет принимать любое число входных аргументов (в т.ч. их полное отсутствие). Значение возвращается из функции с помощью выражения return. Имя функции остаётся на ваш выбор (не используйте пробелы и не начинайте с цифр).
Примечание:
Если функция с выражением return не возвращает значения, будет возвращено None.
Примечание:
Python требует структурированное расположение текста в синтаксисе. Для определения каждого логического уровня используются четыре пробела. Приводите в соответствие начало и конец каждого блока, и будьте последовательны.
Примеры кода – math
Простые математические выражения можно добавлять с помощью параметра Выражение, а более сложные примеры можно создавать с помощью параметров Выражение и Блок кода.
Округлить значения поля до двух десятичных знаков.
Expression:
round(!area!, 2)Используйте модуль math для конвертации метров в футы. Конвертация возводит в степень 2 и умножает на площадь.
Expression:
MetersToFeet((float(!shape.area!)))
Code Block:
import math
def MetersToFeet(area):
    return math.pow(3.2808, 2) * areaВычисления в полях с использованием логики Python
Логические структуры могут быть включены в блок кода через выражения if, else и elif.
Классифицировать на основании значений поля.
Expression:
Reclass(!WELL_YIELD!)
Code Block:
def Reclass(WellYield):
    if (WellYield >= 0 and WellYield <= 10):
        return 1
    elif (WellYield > 10 and WellYield <= 20):
        return 2
    elif (WellYield > 20 and WellYield <= 30):
        return 3
    elif (WellYield > 30):
        return 4Примеры кода – геометрия
Помимо следующих примеров кода см. раздел Преобразование геометрических единиц, расположенный ниже, для получения дополнительной информации о преобразовании геометрических единиц.
Вычислить площадь объекта.
Expression:
!shape.area!Вычислить максимальную x-координату объекта.
Expression:
!shape.extent.XMax!Вычислить количество вершин объекта.
Expression:
getVertexCount(!shape!)
Code Block:
def getVertexCount(feat):    
    partnum = 0
    # Count the number of points in the current multipart feature
    partcount = feat.partCount
    pntcount = 0
    # Enter while loop for each part in the feature (if a singlepart 
    # feature, this will occur only once)
    while partnum < partcount:
        part = feat.getPart(partnum)
        pnt = part.next()
        # Enter while loop for each vertex
        while pnt:
            pntcount += 1   
            pnt = part.next()
   
            # If pnt is null, either the part is finished or there 
            # is an interior ring
            if not pnt: 
                pnt = part.next()
        partnum += 1
    return pntcountДля точечного класса пространственных объектов сдвинуть x-координату каждой точки на 100.
Expression:
shiftXCoordinate(!SHAPE!)
Code Block:
def shiftXCoordinate(shape):
    shiftValue = 100
    point = shape.getPart(0)
    point.X += shiftValue
    return pointИнформация о единицах измерения геометрии
Свойства площади и длины в поле геометрии можно изменить с помощью типов единиц, использующих методы геометрии getArea и getLength.
Узнайте больше о поддерживаемых линейных и площадных единицах измерения в геообработке
Для получения подробной информации см. объекты Polygon и Polyline.
Внимание:
Преобразование единиц площади в географическую систему координат даёт сомнительные результаты, так как десятичные градусы в разных частях глобуса имеют разную длину.
Вычислить длину пространственного объекта в ярдах.
Expression:
!shape@getLength('PLANAR', 'YARDS')Вычислить длину пространственного объекта в акрах.
Expression:
!shape@getArea('PLANAR', 'ACRES')Геодезическая площадь и длина также могут быть вычислены с помощью метода GEODESIC.
Для получения подробной информации см. объекты Polygon и Polyline.
Подробнее об инструментах геообработки и линейных и площадных единицах измерения
Вычисление геодезической длины пространственного объекта в ярдах.
Expression:
!shape@getLength('GEODESIC', 'YARDS')Вычисление геодезической площади пространственного объекта в акрах.
Expression:
!shape@getArea('GEODESIC', 'ACRES')Образцы кода - поля date
Дату и время можно вычислить в модулях datetime и time.
Вычислить текущую дату.
Expression:
time.strftime("%d/%m/%Y")Вычислить текущие дату и время.
Expression:
datetime.now()Вычислите дату: 15 марта 2015 г., 13:30:00.
Expression:
datetime(year=2015, month=3, day=15, hour=13, minute=30, second=0))Вычислить количество дней между текущей датой и значением в поле.
Expression:
datetime.now().day - !OID!Вычислить дату, прибавив 100 дней к значению даты в поле.
Expression:
!field1! + timedelta(days=100)
Code Block:
from datetime import timedeltaВычислите строку, представляющую дату, используя метод ctime в модуле datetime. Пример создает строку в формате: 'Mon Feb 22 10:15:00 2021'.
Expression:
!field1!.ctime()Вычислить день недели (например, воскресенье) для значения даты в поле.
Expression:
!field1!.strftime('%A')Вычислите форматированную строку из поля даты, используя метод datetime модуля strftime и строку в точном формате. Пример создает строку в формате: '02/22/2021, 10:15:00'.
Expression:
!field1!.strftime("%m/%d/%Y, %H:%M:%S")Вычислите дату, используя форматированную строку ISO-8601.
Expression:
'1969-07-21 02:56:00'Вычислите дату, используя соглашение о месяце, дне, годе, времени.
Expression:
'July 1 2020 12:30:45'Образцы кода - поля time only
Рассчитайте время 16:30:00, используя функцию datetime модуля time.
Expression:
time(hour=16, minute=30, second=0)
Code Block:
from datetime import timeПри вычислении поля date в поле time only будет применена только временная часть объекта datetime.
Expression:
!date_field!Образцы кода - поля date only
Вычислить дату как 31 декабря 2000.
Expression:
datetime(2000, 12, 31)При вычислении поля date в поле time only будет применена только временная часть объекта datetime.
Expression:
!date_field!Образцы кода—поля timestamp offset
Добавьте сдвиг метки времени UTC к текущей дате и времени, используя свойство datetime.timezone модуля utc.
Expression:
datetime.now(tz=timezone.utc)
Code Block:
from datetime import timezoneДобавьте сдвиг метки времени к текущей дате и времени, используя класс zoneinfo модуля ZoneInfo, чтобы задать часовой пояс.
Expression:
datetime.now(ZoneInfo('America/New_York'))
Code Block:
from zoneinfo import ZoneInfoПримеры кода – текст
Строковые вычисления в Python могут выполняться разными способами.
Вернуть три самых правых символа.
Expression:
!SUB_REGION![-3:]Заменить все вхождения заглавной буквы P на прописную p.
Expression:
!STATE_NAME!.replace("P","p")Конкатенировать два поля, разделив их пробелом.
Expression:
!SUB_REGION! + " " + !STATE_ABBR!Конвертация в нужный регистр
В этих примерах показаны различные способы конвертации слов таким образом, чтобы каждое слово начиналось с большой буквы, а остальные буквы были прописными.
Expression:
' '.join([i.capitalize() for i in !STATE_NAME!.split(' ')])Expression:
!STATE_NAME!.title()Регулярные выражения
Модуль Python re содержит операции сопоставления регулярных выражений, которые используются для сопоставления сложных примеров и правил замещения для строк.
Замена St или St. перед новым словом в конце строки словом Street.
Expression:
update_street(!ADDRESS!)
Code Block:
import re
def update_street(street_name):
    return re.sub(r"""\b(St|St.)\Z""",  
                  'Street',
                  street_name)Накопительные и последовательные вычисления
Накопительные и последовательные вычисления могут выполняться с использованием глобальных переменных.
Вычислить последовательные идентификаторы ID или порядковые номера на основании интервала.
Expression:
autoIncrement(10, 5)
Code Block:
rec = 0
def autoIncrement(start=1, interval=1):
    global rec
    if rec == 0:
        rec = start
    else:
        rec += interval
    return recВычислить накопительные значения числового поля.
Expression:
accumulate(!FieldA!)
Code Block:
total = 0
def accumulate(increment):
    global total
    if total:
        total += increment
    else:
        total = increment
    return totalВычислить процентное приращение числового поля.
Expression:
percentIncrease(float(!FieldA!))
Code Block:
lastValue = 0
def percentIncrease(newValue):
    global lastValue
    if lastValue:
        percentage = ((newValue - lastValue) / lastValue)  * 100
    else: 
        percentage = 0
    lastValue = newValue
    return percentageСлучайные значения
Случайные значения можно получить с помощью модуля random.
Использование упаковки сайта numpy для вычисления случайных значений с плавающей точкой от 0.0 до 1.0.
Expression:
getRandomValue()
Code Block:
import numpy
def getRandomValue():
    return numpy.random.random()Используйте модуль random для вычисления случайных целочисленных значений от 0 до 10.
Expression:
random.randint(0, 10)
Code Block:
import randomВычислить нулевые значения
С помощью выражения Python можно вычислить пустые значения (null), используя Python None.
Примечание:
Следующее вычисление будет работать, только если поле допускает хранение значений Null.
Используйте None в Python для вычисления нулевых значений.
Expression:
None