需要 Spatial Analyst 许可。
摘要
对两个输入栅格的二进制值执行“按位异或”运算。
插图
用法
要进行此按位操作,需要两个输入值。
使用此工具时输入的顺序不重要。
如果输入为浮点型,则值会在执行按位操作前通过截断转换为整型值。
在按位操作中:
- 二进制值以二的补码的形式存储。
- 工具对 32 位整型起作用。
- 最左边的位会为作为值的符号(正号或负号)而保留。如果为正整型,则该位为 0;如果为负整型,则该位为 1。
“按位异或”运算将符号位视同任意其他位。如果某一像元位置的一个或两个输入为负,则输出为负;如果两个输入都为正,则输出为正。
有关适用于此工具的地理处理环境的详细信息,请参阅分析环境和 Spatial Analyst。
语法
BitwiseXOr (in_raster_or_constant1, in_raster_or_constant2)
参数 | 说明 | 数据类型 |
in_raster_or_constant1 | 按位运算中要使用的第一个输入。 假如已为其他参数指定栅格,则可将数字用作此参数的输入。为了能够为两个输入指定数字,像元大小和范围必须先在环境中进行设置。 | Raster Layer | Constant |
in_raster_or_constant2 | 按位运算中要使用的第二个输入。 假如已为其他参数指定栅格,则可将数字用作此参数的输入。为了能够为两个输入指定数字,像元大小和范围必须先在环境中进行设置。 | Raster Layer | Constant |
返回值
名称 | 说明 | 数据类型 |
out_raster | 输出栅格。 像元值是对两个输入进行“按位异或”运算的结果。 | Raster |
代码示例
按位异或 (BitwiseXOr) 示例 1(Python 窗口)
本例对两个 Grid 栅格执行“按位异或”运算。
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outBitwiseXOr = BitwiseXOr("degs", "negs")
outBitwiseXOr.save("C:/sapyexamples/output/outbitxor")
按位异或 (BitwiseXOr) 示例 2(独立脚本)
此示例对两个 Grid 栅格数据执行“按位异或”运算,并以 IMG 栅格数据的形式输出结果。
# Name: BitwiseXOr_Ex_02.py
# Description: Performs a Bitwise XOr operation on the binary values
# of two input rasters
# 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 = "degs"
inRaster2 = "negs"
# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")
# Execute BitwiseXOr
outBitwiseXOr = BitwiseXOr(inRaster1, inRaster2)
# Save the output
outBitwiseXOr.save("C:/sapyexamples/output/outbitwisexor.img")
环境
许可信息
- ArcGIS for Desktop Basic: 需要 Spatial Analyst
- ArcGIS for Desktop Standard: 需要 Spatial Analyst
- ArcGIS for Desktop Advanced: 需要 Spatial Analyst