当前页面链接:https://www.cnblogs.com/oloroso/p/14864093.html

python 实现批量 WKT 转 KML

使用ogr库实现 wkt 格式的几何数据转换为 kml 格式的简单实现。

Copy Highlighter-hljs
#!/usr/bin/env python
import argparse
import os
from osgeo import ogr # pip install osgeo
# 读取 wkt 文件,这里只返回了第一行
def readWktFile(filename):
f = open(filename)
data = f.readlines()
f.close()
return data[0]
# 参考: https://pcjericks.github.io/py-gdalogr-cookbook/geometry.html
def wkt2kml(wkt):
geometry = ogr.CreateGeometryFromWkt(wkt)
return geometry.ExportToKML()
def wkt2geojson(wkt):
geometry = ogr.CreateGeometryFromWkt(wkt)
return geometry.ExportToJson()
def writeFile(filename, data):
fo = open(filename, "wb")
fo.write(data)
def main():
print("读取指定 wkt 文件列表(一行一个)")
parser = argparse.ArgumentParser(description='转换 WKT 文件为 KML')
parser.add_argument('infile', nargs='?', type=argparse.FileType('r'),default=sys.stdin)
args = parser.parse_args()
wktFileList = args.infile.read().splitlines()
wktDirectory = "wkt/" # wkt 文件所在目录
kmlDirectory = "kml/" # kml 文件输出目录
ogr.RegisterAll()
for wktFile in wktFileList:
print("处理 %s" % wktFile)
wkt = readWktFile(wktDirectory + filename)
kml = wkt2kml(wkt)
# 补全kml文件信息(这里 wkt 文件后缀名都是 .wkt )
prefix = '<?xml version="1.0" encoding="utf-8" ?>\
<kml xmlns="http://www.opengis.net/kml/2.2">\
<Document id="root_doc"><Folder><name>%s</name>\
<Placemark>' % filename[0:-4]
suffix = '</Placemark></Folder></Document></kml>'
kml = prefix + kml + suffix
writeFile(kmlDirectory + filename[0:-4] + ".kml", kml.encode())
if __name__ == "__main__":
main()
posted @   乌合之众  阅读(543)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
clear
点击右上角即可分享
微信分享提示