概述
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中只存放了坐标点,因此只需要提取点即可。
最后
以上就是隐形钢笔为你收集整理的dxf转geojson转csv的全部内容,希望文章能够帮你解决dxf转geojson转csv所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复