代码分享 Python |批量删除栅格影像异常值

任务举例:下载的NPP影响最大值为63355,通过查看栅格数据直方图要删除异常值。

数据准备:文件夹(工作空间)-含有需要批量处理的tif影像

工具准备:Python arcpy 环境
操作:替换代码中的路径即可

# -*- coding: UTF-8 -*-
import arcpy
import os
import glob
import arcpy
from arcpy.sa import *
​
arcpy.CheckOutExtension("ImageAnalyst")  # 检查许可
arcpy.CheckOutExtension("spatial")
​
arcpy.env.workspace = "E:/1/"  #工作空间
rasters = arcpy.ListRasters("*", "tif") #遍历工作空间中的tif格式数据
​
outPath = 'E:/2'
​
whereClause = "VALUE > 3550 "  # 去除异常值
​
# 循环rasters中的所有影像,进行去异常值操作
for ras in rasters:
    outrasters = outPath + str(ras)#更改输出栅格名字
    outSetNull = SetNull(ras, ras, whereClause)  # 去除异常值
    outSetNull.save(outrasters)
    print(str(ras))
print("All project is OK!")

END 更多精彩尽在GeoLab 219

 

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个基于GDAL库的python代码,用于批量将遥感影像栅格化为矢量文件: ```python import os import glob import gdal from osgeo import ogr path = 'path/to/raster/files' output_path = 'path/to/vector/files' def raster_to_vector(raster_file, vector_file): # Open raster file and get metadata ds = gdal.Open(raster_file) band = ds.GetRasterBand(1) geotransform = ds.GetGeoTransform() proj = ds.GetProjection() cols = ds.RasterXSize rows = ds.RasterYSize # Create output shapefile and layer driver = ogr.GetDriverByName('ESRI Shapefile') out_ds = driver.CreateDataSource(vector_file) out_layer = out_ds.CreateLayer(vector_file, srs=ogr.osr.SpatialReference(proj), geom_type=ogr.wkbPolygon) # Create field for pixel value field_def = ogr.FieldDefn('Value', ogr.OFTInteger) out_layer.CreateField(field_def) # Create polygons from raster cells for y in range(rows): for x in range(cols): # Get pixel value and check if it is nodata value = band.ReadAsArray(x, y, 1, 1)[0, 0] if value == band.GetNoDataValue(): continue # Calculate polygon vertices ulx, xres, xskew, uly, yskew, yres = geotransform xcoord = ulx + (x + 0.5) * xres ycoord = uly + (y + 0.5) * yres ring = ogr.Geometry(ogr.wkbLinearRing) ring.AddPoint(xcoord - 0.5 * xres, ycoord - 0.5 * yres) ring.AddPoint(xcoord + 0.5 * xres, ycoord - 0.5 * yres) ring.AddPoint(xcoord + 0.5 * xres, ycoord + 0.5 * yres) ring.AddPoint(xcoord - 0.5 * xres, ycoord + 0.5 * yres) ring.AddPoint(xcoord - 0.5 * xres, ycoord - 0.5 * yres) poly = ogr.Geometry(ogr.wkbPolygon) poly.AddGeometry(ring) # Create feature and add to layer feature = ogr.Feature(out_layer.GetLayerDefn()) feature.SetGeometry(poly) feature.SetField('Value', value) out_layer.CreateFeature(feature) # Clean up ds = None out_ds = None # Loop through raster files for raster_file in glob.glob(os.path.join(path, '*.tif')): # Create output vector file name vector_file = os.path.join(output_path, os.path.splitext(os.path.basename(raster_file))[0] + '.shp') # Convert raster to vector raster_to_vector(raster_file, vector_file) ``` 这个代码将遥感影像文件夹中的所有.tif文件转换为矢量文件,输出到指定的路径下。可以根据需要对输出的矢量文件进行进一步处理,如合并、剪裁等操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值