0

次のサンプルxmlがあります

<osm version="0.6" generator="CGImap 0.3.3 (28791 thorn-03.openstreetmap.org)" copyright="OpenStreetMap and contributors" attribution="http://www.openstreetmap.org/copyright" license="http://opendatacommons.org/licenses/odbl/1-0/">
 <bounds minlat="41.9704500" minlon="-87.6928300" maxlat="41.9758200" maxlon="-87.6894800"/>
 <node id="261114295" visible="true" version="7" changeset="11129782" timestamp="2012-03-28T18:31:23Z" user="bbmiller" uid="451048" lat="41.9730791" lon="-87.6866303"/>

そして、python iter parseを使用してxmlから境界とノードを抽出したい次のコードスニペットを試しました

import xml.etree.cElementTree as ET
import pprint

def count_tags(filename):
    mytags = {}
    osmfile = open('example.osm', 'r')
    for event, elem in ET.iterparse(osmfile,events=('end',)):
        if elem.tag == "tag":
            if elem.attrib['k'] in mytags:
                mytags[elem.attrib['k']] += 1
            else:
                mytags[elem.attrib['k']] = 1

しかし、境界とノードを抽出できません...何が欠けていますか?

4

1 に答える 1

0

とが XML のルートの 1 レベル下にあると仮定するboundsと、次のように動作するはずです。node

def count_tags():
    mytags = {}
    for event, child in ET.iterparse('example.osm'):
        if child.tag in ('bounds', 'node'):
            mytags[child.tag] = child.attrib
    print mytags

出力の呼び出しcount_tags:

{
    'node': {'changeset': '11129782', 'uid': '451048', 'timestamp': '2012-03-28T18:31:23Z', 'lon': '-87.6866303', 'visible': 'true', 'version': '7', 'user': 'bbmiller', 'lat': '41.9730791', 'id': '261114295'}, 
    'bounds': {'minlat': '41.9704500', 'maxlon': '-87.6894800', 'minlon': '-87.6928300', 'maxlat': '41.9758200'}
}
于 2016-10-10T07:42:29.903 に答える