makedbfspec

Спецификация DBF из структуры географических данных

Синтаксис

dbfspec = makedbfspec(S)

Описание

dbfspec = makedbfspec(S) анализирует географическую структуру данных, S, и создает спецификацию DBF, подходящую для использования с shapewrite. Можно изменять dbfspec, затем передайте его в shapewrite для управления тем, какие поля атрибута геоstruct записываются в компонент DBF файла shapefile, шириной поля и точностью, используемой для числовых значений.

dbfspec является скалярным MATLAB® структура с двумя уровнями. Верхний уровень состоит из поля для каждого атрибута в S. Каждое из этих полей, в свою очередь, содержит скалярную структуру с фиксированным набором четырех полей:

Поле dbfspec

Содержание

FieldName

Имя поля, используемое в файле DBF. Это имя будет совпадать с именем соответствующего атрибута, но может быть изменено перед вызовом shapewrite. Это изменение может потребоваться, например, потому, что вы хотите использовать пространства в именах полей DBF, но знаете, что вы не можете использовать пространства для имен переменного MATLAB.

FieldType

Тип поля для использования в файле 'N' (числовой) или 'C' (символ).

FieldLength

Количество байтов, которое каждый образец поля будет занимать в файле.

FieldDecimalCount

Количество цифр справа от десятичного знака, которые хранятся в числовом поле. Нуль для целочисленных полей и символьных полей. Значение по умолчанию для нецелочисленных числовых полей - 6.

Примеры

Импортируйте файл shapefile, представляющий небольшую сеть дорожных сегментов, и создайте спецификацию DBF.

s = shaperead('concord_roads')

s = 
609x1 struct array with fields:
    Geometry
    BoundingBox
    X
    Y
    STREETNAME
    RT_NUMBER
    CLASS
    ADMIN_TYPE
    LENGTH

dbfspec = makedbfspec(s)

dbfspec = 
    STREETNAME: [1x1 struct]
     RT_NUMBER: [1x1 struct]
         CLASS: [1x1 struct]
    ADMIN_TYPE: [1x1 struct]
        LENGTH: [1x1 struct]

Измените спецификацию DBF, чтобы (a) исключить 'ADMIN_TYPE' атрибут, (b) переименовать 'STREETNAME' поле к 'Street Name'и с) сократить количество десятичных знаков, используемых для хранения длин дорог.

dbfspec = rmfield(dbfspec,'ADMIN_TYPE')

dbfspec = 
    STREETNAME: [1x1 struct]
     RT_NUMBER: [1x1 struct]
         CLASS: [1x1 struct]
        LENGTH: [1x1 struct]

dbfspec.STREETNAME.FieldName = 'Street Name';
dbfspec.LENGTH.FieldDecimalCount = 1;

Экспорт сети дорог в измененный файл shapefile. (Фактически, только компонент DBF будет другим.)

shapewrite(s, 'concord_roads_modified', 'DbfSpec', dbfspec)

Проверьте внесенные изменения. Заметьте внешний вид 'Street Name' в именах полей, сообщаемых shapeinfo, отсутствие 'ADMIN_TYPE' поле и уменьшение точности длин дорог.

info = shapeinfo('concord_roads_modified')
info = 
       Filename: [3x28 char]
      ShapeType: 'PolyLine'
    BoundingBox: [2x2 double]
    NumFeatures: 609
     Attributes: [4x1 struct]

{info.Attributes.Name}

ans = 
    'Street Name'    'RT_NUMBER'    'CLASS'    'LENGTH'

r = shaperead('concord_roads_modified')

r = 
609x1 struct array with fields:
    Geometry
    BoundingBox
    X
    Y
    StreetName
    RT_NUMBER
    CLASS
    LENGTH

s(33).LENGTH

ans =
    3.492817400000000e+002

r(33).LENGTH

ans =
    3.493000000000000e+002

См. также

shapeinfo, shapewrite

Представлено до R2006a
Для просмотра документации необходимо авторизоваться на сайте