dxf转geojson转csv

dxf转geojson参考这里

import os
from osgeo import osr, ogr, gdal
import json
import jsonpath
import csv  # 调用数据保存文件
import pandas as pd  # 用于数据输出
def dxf_to_geojson(dxf):
    basename = os.path.split(dxf)[0]
    filename = os.path.basename(dxf).split('.')[0]
    outfile = "{}.json".format(basename + '\\' + filename)

    ogr.RegisterAll()
    gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES")
    gdal.SetConfigOption("SHAPE_ENCODING", "")
    gdal.SetConfigOption("DXF_ENCODING", "ASCII")  # 设置DXF缺省编码
    poDS = ogr.Open(dxf, False)
    poDriver = ogr.GetDriverByName("GeoJson")
    # 保存文件
    res = poDriver.CopyDataSource(poDS, outfile)
    return outfile
def geojson_to_csv(geojsonfile):
    # 读取json文件内容,返回字典格式
    with open(geojsonfile, 'r', encoding='utf8')as fp:
        json_data = json.load(fp)
        # 利用jsonpath语法读取json所有二级对象下存放坐标的coordinates
        point_list = jsonpath.jsonpath(json_data, '$..coordinates')
        column = ['longitude', 'latitude', 'altitude']  # 列表头名称
        tablelist = pd.DataFrame(columns=column, data=point_list)  # 将数据放进表格
        tablelist.to_csv('test.csv')


if __name__ == '__main__':
    geojsonfile = dxf_to_geojson('E:\\pythonProject\\point.dxf')
    geojson_to_csv(geojsonfile)

gdal需要离线安装
参考这里

这个geojson中只存放了坐标点,因此只需要提取点即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值