Eu tenho as seguintes coordenadas
minx, maxx, miny ,maxy = 448262.080078, 450360.750122, 6262492.020081, 6262938.950073
Desejo criar uma grade quadrada de tamanho 1 m usando python.
import math
minx,maxx,miny,maxy = 448262.080078, 450360.750122, 6262492.020081, 6262938.950073
size = 1
def set_bbox(minx, maxx, miny, maxy, distx, disty):
nx = int(math.ceil(abs(maxx - minx)/distx))
ny = int(math.ceil(abs(maxy - miny)/disty))
new_maxx = minx + (nx*distx)
new_miny = maxy - (ny*disty)
return ((minx, new_maxx, new_miny, maxy),ny,nx)
# shift the bottom (right - down)
coord, ny, nx = set_bbox(minx,maxx,miny,maxy,size,size)
# left-up origin
origin = coord[0],coord[3]
# number of tiles
ncell = ny*nx
python
polygon
vector-grid
Gianni
fonte
fonte
Respostas:
O script a seguir fará o trabalho com GDAL e Python:
fonte
Este script Python usa a biblioteca pyshp , conforme sugerido por user16044:
Nota: uma grade quadrada de tamanho 1 m com essa extensão é igual a uma camada que contém cerca de 1 milhão de polígonos e, portanto, o desempenho do script diminui sensivelmente.
fonte
Esta pergunta foi respondida há algum tempo, mas adiciono outra solução usando as bibliotecas shapely e fiona:
fonte
A resposta para Criando Shapefile de grade de rede de pesca no QGIS? mostra uma opção de criação de grade na caixa de ferramentas de processamento do QGIS.
fonte