操作数 | 说明 | 数据类型 |
in_raster_or_constant1 | 分子输入。 如果第一个输入为栅格,第二个输入为标量,则将各输入栅格值除以标量值后,计算所得的余数,从而创建输出栅格。 | Raster Layer | Constant |
in_raster_or_constant2 | 分母输入。 如果第一个输入为标量,第二个输入为栅格,则将标量值除以各输入栅格值后,计算所得的余数,从而创建输出栅格。 | Raster Layer | Constant |
需要 Spatial Analyst 许可。
获得 Image Analyst 许可后可用。
摘要
逐个像元地求出第一个栅格数据除以第二个栅格数据的余数(模)。
插图
说明
使用具有栅格输入的运算符时,结果将为栅格。 但是,如果所有输入均为数字,那么结果也是数字。
当表达式中存在多个运算符时,运算符不一定按照从左到右的顺序运行。 具有最高优先级值的运算符将首先运行。 有关详细信息,请参阅使用“地图代数”中的运算符中的运算符优先级表。 可使用括号来控制运行顺序。
此运算符的结果与输入的顺序有关。
任何值对 0 求模(除以)后的输出结果均为 NoData;因此,第二个输入为 0 或 NoData 的任何位置对应在输出中都将返回 NoData。
模运算符假设它的两个输入都是整数。 如果有任何输入不是整数,则将通过截断将这些输入转换为整数。 输出值始终是整数。
执行求模运算符的另一种方法为 a %= b,其为 a = a % b 的另一种写法。
如果两个输入均为单波段栅格,或者输入之一是常量,则输出将是单波段栅格。
如果两个输入均为多波段栅格,则该运算符将针对一个输入中的每个波段执行运算,并且输出将为多波段栅格。 每个多波段输入中的波段数必须相同。
如果其中一个输入为多波段栅格,而另一个输入为常量,则该运算符将针对多波段输入中每个波段的常量值执行运算,并且输出将为多波段栅格。
如果两个输入均为具有相同数量变量的多维栅格,则该运算符将对具有相同维度值的所有剖切片执行运算,并且输出将为多维栅格。 输入中的变量必须具有相同维度或常见维度,但不能具有不常见的维度。
如果两个输入均具有一个变量但名称不同,请将匹配多维变量环境设置为 False 以执行该运算。
如果其中一个输入为多维栅格,而其他输入为常量,则该运算符将针对常量值对所有变量的所有剖切片执行运算,并且输出将为多维栅格。
参数
代码示例
此示例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outMod = Raster("degs") % Raster("negs")
outMod.save("C:/sapyexamples/output/outmod.tif")
此示例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。
# Name: Op_Mod_Ex_02.py
# Description: Finds the remainder of the first raster when divided by
# the second raster on a cell-by-cell basis
# Requirements: Spatial Analyst Extension
# Import system modules
import arcpy
from arcpy import env
from arcpy.sa import *
# Set environment settings
env.workspace = "C:/sapyexamples/data"
# Set local variables
inRaster1 = Raster("degs")
inRaster2 = Raster("negs")
# Execute Mod
outMod = inRaster1 % inRaster2
# Save the output
outMod.save("C:/sapyexamples/output/outmod")