Skip to main content
Help improve PyPI by participating in a 5-minute user interface survey!

Parse and model Popolo data from EveryPolitician

Project Description

This is a port of the Ruby gem everypolitician-popolo to Python. Even this README is strongly based on that gem.


You can install this package with:

pip install everypolitician-popolo


You can download a Popolo file manually from EveryPolitician (although there’s another library if you want to automate that: See also: the everypolitician package).

The following example uses Åland Lagting (which is the legislature of the Åland islands, available as JSON data from the EveryPolitician page for Åland).

First you’ll need to require the library and read in a file from disk.

from popolo_data.importer import Popolo
popolo = Popolo.from_filename('ep-popolo-v1.0.json')

All Popolo classes used by EveryPolitician are implemented:

There are methods defined for each property on a class, e.g. for a Person:

len(popolo.persons) # => 60
person = popolo.persons.first # => u'e3aab23e-a883-4763-be0d-92e5936024e2' # => u'Aaltonen Carina'
person.image # => u''
person.wikidata # => u"Q4934081"

You can also find individual records or collections based on their attributes:

popolo.persons.get(name="Aaltonen Carina")
    # => <Person: Aaltonen Carina>

    # => [<Organization: Liberalerna>,
    #     <Organization: Liberalerna på Åland r.f.>,
    #     <Organization: Moderat Samling>,
    #     <Organization: Moderat Samling på Åland r.f.>,
    #     <Organization: Moderat samling>,
    #     <Organization: Moderaterna på Åland>,
    #     <Organization: Obunden Samling>,
    #     <Organization: Obunden Samling på Åland>,
    #     <Organization: Ålands Framtid>,
    #     <Organization: Ålands Socialdemokrater>,
    #     <Organization: Ålands framtid>,
    #     <Organization: Ålands socialdemokrater>,
    #     <Organization: Åländsk Center>,
    #     <Organization: Åländsk Center r.f.>,
    #     <Organization: Åländsk Demokrati>,
    #     <Organization: Åländsk center>]


After checking out the repo, install the dependencies with:

pip install -r requirements.txt

You can then run the tests with:


To release a new version, update the version number in and add notes to the CHANGES.txt describing the fixes or new features.

See also: the everypolitician package

In the example above, the Popolo data comes from a downloaded file (ep-popolo-v1.0.json), which is the kind of file you can get from the EveryPolitician website. But your Ruby application can also interact directly with the EveryPolitician data using the everypolitician package, so you don’t need to handle JSON files at all. The value returned from the Legislature.popolo method is a Popolo object, which you can use as above. For example, you can install the package with:

pip install everypolitician

And then use it as follows:

from everypolitician import EveryPolitician

australia = EveryPolitician().country('Australia')
australia.code # => u'AU'
senate = australia.legislature('Senate')
senate.popolo().persons.get(name='Aden Ridgeway') # => <Person: Aden Ridgeway>


Bug reports and pull requests are welcome on GitHub at <>.


The gem is available as open source under the terms of the MIT License.

Release history Release notifications

This version
History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
everypolitician_popolo-0.0.11-py2-none-any.whl (20.7 kB) Copy SHA256 hash SHA256 Wheel py2 Jan 31, 2017
everypolitician-popolo-0.0.11.tar.gz (15.4 kB) Copy SHA256 hash SHA256 Source None Jan 31, 2017

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page