在pykml中,我可以使用以下代码读取文件中的第一个placemark:
with open(filename) as f:
pm = parser.parse(f).getroot().Document.Folder
print "got :"
print pm.Placemark.LineString.coordinates如何将同一文件中的多个placemarks读入python?
发布于 2015-10-25 01:45:38
这是可行的:
with open(filename) as f:
doc = parser.parse(f).getroot().Document.Folder
for pm in doc.iterchildren():
if hasattr(pm, 'LineString'):
print pm.LineString.coordinates发布于 2016-02-04 15:47:07
编辑:一个更简单的解决方案,假设所有的placemarks都在一个文件夹中:
from pykml import parser
with open(filename) as f:
folder = parser.parse(f).getroot().Document.Folder
for pm in folder.Placemark:
print(pm.name)您还可以使用底层xml库lxml的特性来搜索placemark元素。
from pykml import parser
from pykml.factory import nsmap
namespace = {"ns": nsmap[None]}
with open(filename) as f:
root = parser.parse(f).getroot()
pms = root.findall(".//ns:Placemark", namespaces=namespace)
for pm in pms:
print(pm.name)如果您专门搜索具有Linestring子项的placemarks,则还可以使用xpath进行更复杂的搜索。
pms = root.xpath(".//ns:Placemark[.//ns:LineString]", namespaces=namespace)https://stackoverflow.com/questions/33321223
复制相似问题