Создать набор данных LAS (Управление данными)

Уровень лицензии:BasicStandardAdvanced

Краткая информация

Создает набор данных LAS, связанный с одним или более файлами LAS, и, дополнительно, ограничивающие объекты на поверхности.

Рисунок

Создать набор данных LAS

Использование

Синтаксис

CreateLasDataset_management (input, out_las_dataset, {folder_recursion}, {in_surface_constraints}, {spatial_reference}, {compute_stats}, {relative_paths})
ПараметрОбъяснениеТип данных
input
[input,...]

LAS-файлы и папки с LAS-файлами, на которые будет указывать набор данных LAS. Эта информация может быть представлена как строка, содержащая все входные данные, или список строк, содержащих определенные элементы данных (например, "lidar1.las; lidar2.las; folder1; folder2" или ["lidar1.las", "lidar2.las", "folder1", "folder2"]). Более подробно об использовании списков в входных данных см. в разделе Понимание синтаксиса инструмента.

File; Folder
out_las_dataset

Набор данных LAS, который будет создан.

LAS Dataset
folder_recursion
(дополнительно)

Определяет, добавляются ли лазерные данные в поддиректориях входной папки в набор данных LAS.

  • NO_RECURSIONТолько файлы лидара во входной папке добавляются в набор данных LAS. Это значение используется по умолчанию.
  • RECURSIONВсе LAS-файлы в поддиректориях входной папки добавляются в набор данных LAS.
Boolean
in_surface_constraints
[[in_feature_class, height_field, SF_type],...]
(дополнительно)

Классы объектов, на который ссылается набор данных LAS. Для каждого объекта необходимо определить следующие свойства:

in_feature_class – класс объектов, на который ссылается набор данных LAS.

height_field – поле, задающее источник значений высот для объектов. В таблице атрибутов объекта можно использовать любое числовое поле. Если объект поддерживает z-значения, геометрию объектов можно прочитать, выбрав опцию Shape.Z. Если высота не требуется, укажите ключевое слово <None>, чтобы создать объекты без Z значений, высота которых будет интерполирована на основе поверхности.

SF_type – тип объекта поверхности, который определяет, каким образом геометрия участвует в процессе триангуляции поверхности. Опции с резким или нерезким обозначением указывают, представляют ли ребра объектов резкие перегибы уклонов или плавные изменения уклона.

  • Точки якоря (anchorpoints) – точки высот, которые никогда не удаляются при прореживании. Эта опция доступна только для геометрии отдельных точечных объектов.
  • Резкий перегиб (hardline) или нерезкий перегиб (softline) – линии перегибов, которые задают значение высоты.
  • Резкое отсечение (hardclip) или нерезкое отсечение (softclip) – набор полигональных данных, который определяет границу набора данных LAS.
  • Резкое стирание (harderase) или нерезкое стирание (softerase) – набор полигональных данных, который задает пробелы в наборе данных LAS.
  • Резкая замена (hardreplace) или нерезкая замена (softreplace) – набор данных полигона, который определяет области постоянной высоты.
Value Table
spatial_reference
(дополнительно)

Пространственная привязка набора данных LAS. Если в элементе не содержится информации о системе координат, набор данных LAS использует систему координат первого входного LAS-файла. Если входные файлы не содержат информацию о пространственной привязке, и свойство Входная система координат (Input Coordinate System) не установлено, система координат набора данных LAS определяется как неизвестная.

Coordinate System
compute_stats
(дополнительно)

Определяет, будет ли вычисляться статистика для файлов LAS и пространственный индекс для набора данных LAS. Наличие статистики позволяет использовать опции фильтрации и символов для слоя набора данных LAS, чтобы показывать только атрибутивные значения LAS, существующие в файлах LAS. Дополнительный файл .lasx создается для каждого файла LAS.

  • COMPUTE_STATSСтатистика будет рассчитана.
  • NO_COMPUTE_STATSСтатистика не будет рассчитана. Это значение используется по умолчанию.
Boolean
relative_paths
(дополнительно)

Определяет, будут ли файлы лидар и ограничивающие объекты поверхности, на которые ссылается набор данных LAS храниться с относительными или с абсолютными путями. Использование относительных путей позволит сохранить доступ к источникам, если набор данных LAS, и данные, на которые он ссылается, будут перемещены в другое местоположение.

  • ABSOLUTE_PATHSДля связи с данными набор данных LAS будет использовать абсолютные пути. Это значение используется по умолчанию.
  • RELATIVE_PATHSДля связи с данными набор данных LAS будет использовать относительные пути.
Boolean

Пример кода

Пример CreateLasDataset 1 (окно Python)

В следующем примере показано использование этого инструмента в окне Python:

import arcpy
from arcpy import env

env.workspace = "C:/data"
arcpy.CreateLasDataset_management("folder_a; folder_b/5S4E.las", 
                                "test.lasd", "RECURSION",
                                "LA/boundary.shp <None> Softclip;"\
                                "LA/ridges.shp Elevation hardline", "", 
                                "COMPUTE_STATS", "RELATIVE_PATHS")
Пример CreateLasDataset 2 (автономный скрипт)

В следующем примере показано использование этого инструмента в автономном скрипте Python:

'''*********************************************************************
Name: Export Elevation Raster from Ground LAS Measurements
Description: This script demonstrates how to export
             ground measurements from LAS files to a raster using a 
             LAS dataset. This sample is designed to be used as a script
             tool.
*********************************************************************'''
# Import system modules
import arcpy
import exceptions, sys, traceback

try:
    # Set Local Variables
    inLas = arcpy.GetParameterAsText(0)
    recursion = arcpy.GetParameterAsText(1)
    surfCons = arcpy.GetParameterAsText(2)
    classCode = arcpy.GetParameterAsText(3)
    returnValue = arcpy.GetParameterAsText(4)
    spatialRef = arcpy.GetParameterAsText(5)
    lasD = arcpy.GetParameterAsText(6)
    outRaster = arcpy.GetParameterAsText(7)
    cellSize = arcpy.GetParameter(8)
    zFactor = arcpy.GetParameter(9)
    if arcpy.ProductInfo == 'ArcView':
        arcpy.CheckOutExtension('3D')
    # Execute CreateLasDataset
    arcpy.management.CreateLasDataset(inLas, lasD, recursion, surfCons, sr)
    # Execute MakeLasDatasetLayer
    lasLyr = arcpy.CreateUniqueName('Baltimore')
    arcpy.management.MakeLasDatasetLayer(lasD, lasLyr, classCode, returnValue)
    # Execute LasDatasetToRaster
    arcpy.conversion.LasDatasetToRaster(lasLyr, outRaster, 'ELEVATION',
                              'TRIANGULATION LINEAR WINDOW_SIZE 10', 'FLOAT',
                              'CELLSIZE', cellSize, zFactor)
    arcpy.GetMessages()
    
except arcpy.ExecuteError:
    print arcpy.GetMessages()
    
except:
    # Get the traceback object
    tb = sys.exc_info()[2]
    tbinfo = traceback.format_tb(tb)[0]
    # Concatenate error information into message string
    pymsg = 'PYTHON ERRORS:\nTraceback info:\n{0}\nError Info:\n{1}'\
          .format(tbinfo, str(sys.exc_info()[1]))
    msgs = 'ArcPy ERRORS:\n {0}\n'.format(arcpy.GetMessages(2))
    # Return python error messages for script tool or Python Window
    arcpy.AddError(pymsg)
    arcpy.AddError(msgs)
    
finally:
    arcpy.management.Delete(lasLyr)

Параметры среды

Связанные темы

Информация о лицензировании

ArcGIS for Desktop Basic: Требует Дополнительный модуль 3D Analyst или Spatial Analyst
ArcGIS for Desktop Standard: Да
ArcGIS for Desktop Advanced: Да
5/10/2014