根据 Shp 文件 输出 GeoJson 文件

根据 Shp 文件 输出 GeoJson 文件


  • pom
	<repositories>
        <repository>
            <id>osgeo</id>
            <name>OSGeo Release Repository</name>
            <url>https://repo.osgeo.org/repository/release/</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
            <releases>
                <enabled>true</enabled>
            </releases>
        </repository>
        <repository>
            <id>osgeo-snapshot</id>
            <name>OSGeo Snapshot Repository</name>
            <url>https://repo.osgeo.org/repository/snapshot/</url>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
            <releases>
                <enabled>false</enabled>
            </releases>
        </repository>
    </repositories>

	<properties>
        <java.version>1.8</java.version>
        <geotools.version>21.4</geotools.version>
    </properties>

    <dependencies>
    	<!--GeoTools-->
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-shapefile</artifactId>
            <version>${geotools.version}</version>
        </dependency>

        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-geojson</artifactId>
            <version>${geotools.version}</version>
        </dependency>
     </dependencies>
  • 根据 Shp 文件 输出 GeoJson 文件
public void generateGeoJsonFileFromShp() {
        File shpFile = new File("D:\\data\\test.shp");
        File geoJsonFile = new File("D:\\data\\test.geojson");
        String charset = "GB2312";
        try (BufferedWriter writer = new BufferedWriter(new FileWriter(geoJsonFile))) {
            ShapefileDataStore shapefileDataStore = new ShapefileDataStore(shpFile.toURI().toURL());
            shapefileDataStore.setCharset(Charset.forName(charset));

            ContentFeatureSource featureSource = shapefileDataStore.getFeatureSource();

            ContentFeatureCollection features = featureSource.getFeatures();
            FeatureJSON featureJSON = new FeatureJSON();

            featureJSON.writeFeatureCollection(features, writer);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

Mr.superbeyone


将Shapefile(.shp)格式转换为GeoJSON格式,可以通过多种软件工具或编程库来实现。以下是一些常见的转换方法: 1. 使用开源GIS软件QGIS: - 打开QGIS。 - 选择“矢量”菜单中的“研究工具” -> “导入/导出” -> “导出图层为GeoJSON”。 - 在弹出的对话框中选择你的.shp文件,然后输入输出路径和文件名,选择保存GeoJSON格式。 - 点击“确定”进行转换。 2. 使用命令行工具ogr2ogr: - ogr2ogr是GDAL/OGR库中的一部分,可以在命令行中使用。 - 打开命令行工具(例如,命令提示符或终端)。 - 输入以下命令:`ogr2ogr -f GeoJSON output.json input.shp`。 - 该命令会将名为`input.shp`的文件转换为名为`output.json`的GeoJSON文件。 3. 使用编程语言和相关库,例如Python: - 在Python中可以使用`fiona`或`geopandas`库来转换格式。 - 使用`fiona`的示例代码: ```python import fiona from fiona.transform import transform from shapely.geometry import shape # 读取Shapefile with fiona.open("input.shp") as source: schema = source.schema # 将坐标转换为WGS84坐标系(如果需要) for feature in source: geom = shape(feature['geometry']) geom_wgs84 = transform(source.crs, {'init': 'epsg:4326'}, geom) feature['geometry'] = geom_wgs84.__geo_interface__ # 写入GeoJSON文件 with open('output.geojson', 'w') as dst: dst.write(json.dumps(feature)) ``` - 使用`geopandas`的示例代码: ```python import geopandas as gpd # 读取Shapefile gdf = gpd.read_file("input.shp") # 将Shapefile保存GeoJSON gdf.to_file("output.geojson", driver='GeoJSON') ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

superbeyone

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

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

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

打赏作者

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

抵扣说明:

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

余额充值