我正在尝试从KML文件中提取两个不同的元素并将它们转换为CSV。我从这里的伟大网站开始:http://ckdake.com/content/2012/highgroove-hack-night-kml-heatmaps.html生成一个坐标csv。我现在要做的就是将名称标签添加到每行的开头。我是一个ruby / nokogiri n00b所以我可以坚持使用这个代码来获取a)所有名称的列表,然后是b)所有坐标的列表。但同样 - 我希望他们在同一条线上。
require 'rubygems'
require 'nokogiri' # gem install nokogiri
@doc = Nokogiri::XML(File.open("WashingtonDC2013-01-04 12h09m01s.kml"))
@doc.css('name').each do |name|
puts name.content
end
@doc.css('coordinates').each do |coordinates|
coordinates.text.split(' ').each do |coordinate|
(lat,lon,elevation) = coordinate.split(',')
puts "#{lat},#{lon}\n"
end
end
答案 0 :(得分:4)
这个怎么样:
@doc.css('Placemark').each do |placemark|
name = placemark.css('name')
coordinates = placemark.at_css('coordinates')
if name && coordinates
print name.text + ","
coordinates.text.split(' ').each do |coordinate|
(lon,lat,elevation) = coordinate.split(',')
print "#{lat},#{lon}"
end
puts "\n"
end
end
我假设每个<coordinates>
的{{1}}标签中有一个坐标对。如果还有更多,它们都将被附加到同一行。
如果这不起作用,您需要发布一些KML文件本身,以便我可以对其进行测试。我只是基于this sample KML file进行猜测。