11.shpfile读取数据之java-geotools

本文介绍了如何使用JavaGeoTools库通过指定shp文件路径和过滤条件,设置正确的DBF编码(如GBK或UTF-8),以避免读取时出现乱码,最终获取SimpleFeatureCollection对象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于java geotools库读取shp文件

通过shpDataStore.setCharset设置dbf编码,确保与源文件编码一致,不然会出现乱码

话不多说直接上代码

/***
    * path shp文件路径
    * filters 属性过滤条件
    * */
    public SimpleFeatureCollection readStoreByShp(String path, List<Filter> filters) throws IOException {
    ShapefileDataStore shpDataStore = null;
    File file = new File(path);
    shpDataStore = new ShapefileDataStore(file.toURL());
    // 设置编码
    // if(code.equals("GBK")) {
        Charset charset = Charset.forName("GBK");
        shpDataStore.setCharset(charset);
    // }else {
    //     Charset charset = Charset.forName("UTF-8");
    //     shpDataStore.setCharset(charset);
    // }
    String typeName = shpDataStore.getTypeNames()[0];
    SimpleFeatureSource featureSource = null;
    featureSource = shpDataStore.getFeatureSource(typeName);
    Query query = new Query();
    FilterFactory2 ff = CommonFactoryFinder.getFilterFactory2();
    query.setFilter(ff.and(filters));
    SimpleFeatureCollection result = featureSource.getFeatures(query);
    shpDataStore.dispose();// 使用之后必须关掉
    return result;
}
GeoTools是一个开源的Java库,用于读写地理数据,如Shapefile、GeoJSON等。在Java中使用GeoTools将GeoJSON转换为Shapefile(SHP文件),你需要先添加GeoTools的依赖到你的项目中。以下是一个简单的示例代码,说明如何进行转换: ```java import org.geotools.data.DataStoreFinder; import org.geotools.data.shapefile.ShapefileDataStore; import org.geotools.data.simple.SimpleFeatureSource; import org.geotools.geojson.feature.FeatureJSON; import org.locationtech.jts.geom.Geometry; import org.opengis.feature.simple.SimpleFeature; import java.io.File; import java.util.HashMap; import java.util.Map; public class GeoJsonToShpConverter { public void convertGeoJsonToShp(String geojsonFilePath, String shpOutputPath) throws Exception { // 读取GeoJSON文件 FeatureJSON featureJson = new FeatureJSON(); SimpleFeature[] features = featureJson.readFeatures(new File(geojsonFilePath)); // 创建Shapefile文件的输出目录 File shpFile = new File(shpOutputPath + File.separator + "data.shp"); shpFile.getParentFile().mkdirs(); // 设置Shapefile文件的数据源 Map<String, Object> params = new HashMap<>(); params.put("url", shpFile.toURI().toURL()); params.put("create spatial index", Boolean.TRUE); ShapefileDataStore dataStore = new ShapefileDataStore(shpFile.toURI().toURL()); // 设置Shapefile的数据模式 String[] names = new String[features[0].getFeatureType().getAttributeCount()]; int i = 0; for (Object name : features[0].getFeatureType().getAttributeDescriptors().stream().map(Object::toString).toArray()) { names[i++] = (String) name; } dataStore.createSchema(features[0].getFeatureType()); dataStore.getSchema().setAttributeDescriptors(features[0].getFeatureType().getAttributeDescriptors()); dataStore.getSchema().setGeometryDescriptor(features[0].getFeatureType().getGeometryDescriptor()); // 写入数据到Shapefile String typeName = dataStore.getTypeNames()[0]; SimpleFeatureSource featureSource = dataStore.getFeatureSource(typeName); if (featureSource instanceof SimpleFeatureSource) { SimpleFeatureSource fs = (SimpleFeatureSource) featureSource; if (fs.getFeatures() == null || fs.getFeatures().size() == 0) { System.out.println("writing features"); if (fs instanceof SimpleFeatureSource) { ((SimpleFeatureSource) fs).createFeatures(features); } } else { System.out.println("Features already exist"); } } else { System.out.println("Can't create feature writer for this type of data"); } // 关闭数据源 dataStore.dispose(); } public static void main(String[] args) { try { GeoJsonToShpConverter converter = new GeoJsonToShpConverter(); converter.convertGeoJsonToShp("path/to/your/input.geojson", "path/to/output/directory"); } catch (Exception e) { e.printStackTrace(); } } } ``` 在使用上述代码之前,请确保你已经将GeoTools的依赖添加到你的项目中。转换过程主要包括读取GeoJSON文件、创建Shapefile的数据源以及写入数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

紫雪giser

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值