1Geo::ShapeFile(3) User Contributed Perl Documentation Geo::ShapeFile(3)
2
3
4
6 Geo::ShapeFile - Perl extension for handling ESRI GIS Shapefiles.
7
9 use Geo::ShapeFile;
10
11 my $shapefile = Geo::ShapeFile->new('roads');
12
13 # note that IDs are 1-based
14 foreach my $id (1 .. $shapefile->shapes()) {
15 my $shape = $shapefile->get_shp_record($id);
16 # see Geo::ShapeFile::Shape docs for what to do with $shape
17
18 my %db = $shapefile->get_dbf_record($id);
19 }
20
21 # As before, but do not cache any data.
22 # Useful if you have large files and only need to access
23 # each shape once or a small nmber of times.
24 my $shapefile = Geo::ShapeFile->new('roads', {no_cache => 1});
25
27 The Geo::ShapeFile module reads ESRI ShapeFiles containing GIS mapping
28 data, it has support for shp (shape), shx (shape index), and dbf (data
29 base) formats.
30
32 The Geo::ShapeFile module reads ESRI ShapeFiles containing GIS mapping
33 data, it has support for shp (shape), shx (shape index), and dbf (data
34 base) formats.
35
37 new ($filename_base)
38 new ($filename_base, {no_cache => 1})
39 Creates a new shapefile object. The first argument is the basename
40 for your data (there is no need to include the extension, the
41 module will automatically find the extensions it supports). For
42 example if you have data files called roads.shp, roads.shx, and
43 roads.dbf, use "Geo::ShapeFile->new("roads");" to create a new
44 object, and the module will load the data it needs from the files
45 as it needs it.
46
47 The second (optional) argument is a hashref. Currently only
48 no_cache is supported. If specified then data will not be cached
49 in memory and the system will read from disk each time you access a
50 shape. It will save memory for large files, though.
51
52 type_is ($type)
53 Returns true if the major type of this data file is the same as the
54 type passed to type_is().
55
56 The $type argument can be either the numeric code (see
57 "shape_type"), or the string code (see "shape_type_text").
58
59 get_dbf_record ($record_index)
60 Returns the data from the dbf file associated with the specified
61 record index (shapefile indexes start at 1). If called in a list
62 context, returns a hash, if called in a scalar context, returns a
63 hashref.
64
65 x_min() x_max() y_min() y_max()
66 m_min() m_max() z_min() z_max()
67 Returns the minimum and maximum values for x, y, z, and m fields as
68 indicated in the shp file header.
69
70 upper_left_corner() upper_right_corner()
71 lower_left_corner() lower_right_corner()
72 Returns a Geo::ShapeFile::Point object indicating the respective
73 corners.
74
75 height() width()
76 Returns the height and width of the area contained in the shp file.
77 Note that this likely does not return miles, kilometers, or any
78 other useful measure, it simply returns x_max - x_min, or y_max -
79 y_min. Whether this data is a useful measure or not depends on
80 your data.
81
82 corners()
83 Returns a four element array consisting of the corners of the area
84 contained in the shp file. The corners are listed clockwise
85 starting with the upper left. (upper_left_corner,
86 upper_right_corner, lower_right_corner, lower_left_corner)
87
88 area_contains_point ($point, $x_min, $y_min, $x_max, $y_max)
89 Utility function that returns true if the Geo::ShapeFile::Point
90 object in point falls within the bounds of the rectangle defined by
91 the area indicated. See bounds_contains_point() if you want to
92 check if a point falls within the bounds of the current shp file.
93
94 bounds_contains_point ($point)
95 Returns true if the specified point falls within the bounds of the
96 current shp file.
97
98 file_version()
99 Returns the ShapeFile version number of the current shp/shx file.
100
101 shape_type()
102 Returns the shape type contained in the current shp/shx file. The
103 ESRI spec currently allows for a file to contain only a single type
104 of shape (null shapes are the exception, they may appear in any
105 data file). This returns the numeric value for the type, use
106 type() to find the text name of this value.
107
108 shapes()
109 Returns the number of shapes contained in the current shp/shx file.
110 This is the value that allows you to iterate through all the shapes
111 using "for(1 .. $obj->shapes()) {".
112
113 records()
114 Returns the number of records contained in the current data. This
115 is similar to shapes(), but can be used even if you don't have
116 shp/shx files, so you can access data that is stored as dbf, but
117 does not have shapes associated with it.
118
119 shape_type_text()
120 Returns the shape type of the current shp/shx file (see
121 shape_type()), but as the human-readable string type, rather than
122 an integer.
123
124 get_shx_record ($record_index)
125 get_shx_record_header ($record_index)
126 Get the contents of an shx record or record header (for
127 compatibility with the other get_* functions, both are provided,
128 but in the case of shx data, they return the same information).
129 The return value is a two element array consisting of the offset in
130 the shp file where the indicated record begins, and the content
131 length of that record.
132
133 get_shp_record_header ($record_index)
134 Retrieve an shp record header for the specified index. Returns a
135 two element array consisting of the record number and the content
136 length of the record.
137
138 get_shp_record ($record_index)
139 Retrieve an shp record for the specified index. Returns a
140 Geo::ShapeFile::Shape object.
141
142 shapes_in_area ($x_min, $y_min, $x_max, $y_max)
143 Returns an array of integers listing which shape IDs have bounding
144 boxes that overlap with the area specified.
145
146 check_in_area ($x1_min, $y1_min, $x1_max, $y1_max, $x2_min, $x2_max,
147 $y2_min, $y2_max)
148 Returns true if the two specified areas overlap.
149
150 bounds()
151 Returns the bounds for the current shp file. (x_min, y_min, x_max,
152 y_max)
153
154 shx_handle() shp_handle() dbf_handle()
155 Returns the file handles associated with the respective data files.
156
157 type ($shape_type_number)
158 Returns the name of the type associated with the given type id
159 number.
160
161 find_bounds (@shapes)
162 Takes an array of Geo::ShapeFile::Shape objects, and returns a
163 hash, with keys of x_min, y_min, x_max, y_max, with the values for
164 each of those bounds.
165
166 get_dbf_field_names()
167 Returns an array of the field names in the dbf file, in file order.
168 Returns an array reference if used in scalar context.
169
170 get_all_shapes()
171 Returns an array (or arrayref in scalar context) with all shape
172 objects in the shapefile.
173
174 get_shapes_sorted()
175 get_shapes_sorted (\@shapes, \&sort_sub)
176 Returns an array (or arrayref in scalar context) of shape objects
177 sorted by ID. Defaults to all shapes, but will also take an array
178 of Geo::ShapeFile::Shape objects. Sorts by record number by
179 default, but you can pass your own sub for more fancy work.
180
181 get_shapes_sorted_spatially()
182 get_shapes_sorted_spatially (\@shapes, \&sort_sub)
183 Convenience wrapper around get_shapes_sorted to sort spatially
184 (south-west to north-east) then by record number. You can pass
185 your own shapes and sort sub. The sort sub does not need to be
186 spatial since it will sort by whatever you say, but it is your code
187 so do what you like.
188
189 build_spatial_index()
190 Builds a spatial index (a Tree::R object) and returns it. This
191 will be used internally for many of the routines, but you can use
192 it directly if useful.
193
194 get_spatial_index()
195 Returns the spatial index object, or "undef" if one has not been
196 built.
197
198 get_dbf_field_info()
199 Returns an array of hashes containing information about the fields.
200 Useful if you are modifying the shapes and then writing them out to
201 a new shapefile using Geo::Shapefile::Writer.
202
204 Please send any bugs, suggestions, or feature requests to
205 <https://github.com/shawnlaffan/Geo-ShapeFile/issues>.
206
208 Geo::ShapeFile::Shape, Geo::ShapeFile::Point, Geo::Shapefile::Writer,
209 Geo::GDAL::FFI
210
212 Jason Kohles, <email@jasonkohles.com>
213
214 Shawn Laffan, <shawnlaffan@gmail.com>
215
217 Copyright 2002-2013 by Jason Kohles (versions up to and including 2.52)
218
219 Copyright 2014 by Shawn Laffan (versions 2.53 -)
220
221 This library is free software; you can redistribute it and/or modify it
222 under the same terms as Perl itself.
223
224
225
226perl v5.34.0 2022-01-21 Geo::ShapeFile(3)