답변:
가능한 두 가지 쉬운 방법 :
1.)
"Corine@1" = 23
. 값이 23 인 모든 셀을 새 래스터로 추출합니다.2.) 래스터 셀 수에 대해보다 정교한 개요를 원한다면 QGIS 용 LecoS 플러그인을 사용할 수 있습니다.
편집 3 : 아래 코드를 다음과 같은 출력을 제공하는 매우 유용한 SEXTANTE 스크립트로 변환했습니다.
자세한 지침 및 다운로드 링크는 여기를 참조하십시오 .
이 작업에 파이썬 콘솔을 사용할 수 있습니다. 아래에 제공된 코드를 복사하여 텍스트 파일에 붙여넣고 예를 들어 "some_script.py"로 저장하십시오. 다음에 QGIS에서 python console을 열어 셀 값을 계산해야 할 때 'show editor'버튼을 누르고이 스크립트를 엽니 다. 그런 다음 스크립트의 네 번째 행에있는 'raster_path'를 래스터의 실제 경로로 바꾸고 변경 사항을 저장하십시오. 그런 다음 스크립트를 실행하고 콘솔 출력 (아래 스크린 샷의 편집기에서 왼쪽)에 래스터에있는 모든 값에 대한 셀 수가 표시됩니다.
이 스크립트가 작동하려면 python-numpy가 설치되어 있어야합니다.
편집 : 또한 정확한 값이 필요하지 않지만 값의 분포를보고 싶다면 여기에 설명 된 접근법을 사용할 수 있습니다 .
편집 2 : 더 고급 버전의 스크립트가 제공되었습니다. 이제 다중 대역 래스터와 함께 작동하고 NaN 값을 처리합니다.
from osgeo import gdal
import sys
import math
path = "raster_path"
gdalData = gdal.Open(path)
if gdalData is None:
sys.exit( "ERROR: can't open raster" )
# get width and heights of the raster
xsize = gdalData.RasterXSize
ysize = gdalData.RasterYSize
# get number of bands
bands = gdalData.RasterCount
# process the raster
for i in xrange(1, bands + 1):
band_i = gdalData.GetRasterBand(i)
raster = band_i.ReadAsArray()
# create dictionary for unique values count
count = {}
# count unique values for the given band
for col in range( xsize ):
for row in range( ysize ):
cell_value = raster[row, col]
# check if cell_value is NaN
if math.isnan(cell_value):
cell_value = 'Null'
# add cell_value to dictionary
try:
count[cell_value] += 1
except:
count[cell_value] = 1
# print results sorted by cell_value
for key in sorted(count.iterkeys()):
print "band #%s - %s: %s" %(i, key, count[key])
count = dict(zip(*numpy.unique(a, return_counts=True)))
. 그래도 메모리 오류를 피하기 위해 64 비트 Python을 실행해야합니다. 비록 그것이 어떻게 처리되는지 테스트하지는 않았습니다 NaN
.