java geo_科学网-java利用geotools读写shp以及相关的文件-林清莹的博文

本文介绍了如何使用Java的GeoTools库来读取和写入SHP文件,包括读取SHP、DBF和SHX文件,以及创建新的SHP文件。示例代码展示了读取DBF文件、读取所有相关文件、写入SHP文件的详细步骤,适用于处理地理空间数据。
摘要由CSDN通过智能技术生成

利用java读取shp以及相关的文件

对应geotools版本:2.7.2

读shape文件。

shape格式文件最少包含3个文件,他们的后缀是:.shp, .dbf, .shx。

.shp存储地理形状和位置信息,.dbf存储属性信息,.shx是索引文件。

单独读取DBF文件

public void readDBF(String path) {

Java代码DbaseFileReader reader = null;

try {

reader = new DbaseFileReader(new ShpFiles(path), false, Charset.forName("GBK"));

DbaseFileHeader header = reader.getHeader();

int numFields = header.getNumFields();

//迭代读取记录

while (reader.hasNext()) {

try {

Object[] entry = reader.readEntry();

for (int i=0; i

String title = header.getFieldName(i);

Object value = entry[i];

System.out.println(title+"="+value);

}

} catch (Exception e) {

e.printStackTrace();

}

}

} catch (Exception e) {

e.printStackTrace();

} finally {

if (reader != null) {

//关闭

try {reader.close();} catch (Exception e) {}

}

}

}

读取3个文件,以point为例:

public void readSHP(String path) {

Java代码ShapefileDataStore shpDataStore = null;

try{

shpDataStore = new ShapefileDataStore(new File(path).toURI().toURL());

shpDataStore.setStringCharset(Charset.forName("GBK"));

String typeName = shpDataStore.getTypeNames()[0];

FeatureSource featureSource = null;

featureSource = (FeatureSource)shpDataStore.getFeatureSource(typeName);

FeatureCollection result = featureSource.getFeatures();

System.out.println(result.size());

FeatureIterator itertor = result.features();

while(itertor.hasNext()){

SimpleFeature feature = itertor.next();

Collection p = feature.getProperties();

Iterator it = p.iterator();

while(it.hasNext()) {

Property pro = it.next();

if (pro.getValue() instanceof Point) {

System.out.println("PointX = " + ((Point)(pro.getValue())).getX());

System.out.println("PointY = " + ((Point)(pro.getValue())).getY());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Geotools库来读写shp文件。下面是一个简单的示例代码,可以读取shp文件并打印出其属性表信息: ```java import java.io.File; import java.io.IOException; import org.geotools.data.DataStore; import org.geotools.data.DataStoreFinder; import org.geotools.data.simple.SimpleFeatureCollection; import org.geotools.data.simple.SimpleFeatureIterator; import org.opengis.feature.simple.SimpleFeature; import org.opengis.feature.simple.SimpleFeatureType; public class ShpFileReader { public static void main(String[] args) throws IOException { // 读取shp文件 File file = new File("path/to/shapefile.shp"); DataStore dataStore = DataStoreFinder.getDataStore(file); String typeName = dataStore.getTypeNames()[0]; SimpleFeatureType schema = dataStore.getSchema(typeName); // 获取属性表信息 System.out.println("Feature Type: " + typeName); System.out.println("Number of attributes: " + schema.getAttributeCount()); System.out.println("Attributes: "); for (int i = 0; i < schema.getAttributeCount(); i++) { System.out.println(schema.getAttributeDescriptors().get(i).getName()); } // 获取要素信息 SimpleFeatureCollection collection = dataStore.getFeatureSource(typeName).getFeatures(); try (SimpleFeatureIterator features = collection.features()) { while (features.hasNext()) { SimpleFeature feature = features.next(); System.out.println(feature.getID() + ": " + feature.getDefaultGeometryProperty().getValue()); } } dataStore.dispose(); } } ``` 需要注意的是,需要在pom.xml中添加geotools依赖: ```xml <dependency> <groupId>org.geotools</groupId> <artifactId>gt-shapefile</artifactId> <version>24.0</version> </dependency> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值