У меня есть следующие координаты
minx, maxx, miny ,maxy = 448262.080078, 450360.750122, 6262492.020081, 6262938.950073
Я хочу создать квадратную сетку размером 1 м, используя 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
Джанни
источник
источник
Ответы:
Следующий скрипт выполнит работу с GDAL и Python:
источник
Этот скрипт на Python использует библиотеку pyshp , как предложено user16044:
Примечание: квадратная сетка размером 1 м с такой протяженностью равна слою, содержащему около 1 миллиона полигонов, поэтому производительность сценария заметно снижается.
источник
На этот вопрос уже давно дан ответ, но я добавляю еще одно решение с использованием библиотек shapely и fiona:
источник
Ответ на Создание сетки сетки Shapefile в QGIS? показывает опцию создания сетки в панели инструментов обработки QGIS.
источник