swissvotes.models.vote
Attributes
Classes
A shorthand property to return the label of an encoded value. Requires |
|
A shorthand property to return a localized attribute. Requires at least |
|
A single vote as defined by the code book. |
Module Contents
- class swissvotes.models.vote.encoded_property(nullable: bool = True)[source]
A shorthand property to return the label of an encoded value. Requires the instance the have a codes-lookup function. Creates the SqlAlchemy Column (with a prefixed underline).
Example:
- class MyClass:
value = encoded_property()
- def codes(self, attributes):
return {0: ‘None’, 1: ‘One’}
- class swissvotes.models.vote.localized_property[source]
Bases:
Generic
[StrT
]A shorthand property to return a localized attribute. Requires at least a xxx_de attribute and falls back to this.
Example:
- class MyClass:
value_de = Column(Text) value_fr = Column(Text) value = localized_property()
- class swissvotes.models.vote.SwissVote[source]
Bases:
onegov.core.orm.Base
,onegov.core.orm.mixins.TimestampMixin
,onegov.swissvotes.models.file.LocalizedFiles
,onegov.core.orm.mixins.ContentMixin
A single vote as defined by the code book.
There are a lot of columns:
Some general, ready to be used attributes (bfs_number, …)
Encoded attributes, where the raw integer value is stored prefixed with an underline and the attribute returns a translatable label by using the
codes
function, e.g._legal_form
,legal_form
andcodes(' _legal_form')
.Descriptors, easily accessible by using
policy_areas
.A lot of lazy loaded, cantonal results only used when importing/exporting the dataset.
Recommendations from different parties and assocciations. Internally stored as JSON and easily accessible and group by slogan with
recommendations_parties
,recommendations_divergent_parties
andrecommendations_associations
.Different localized attachments, some of them indexed for full text search.
Metadata from external information sources such as Museum für Gestaltung can be stored in the content or meta field provided by the
ContentMixin
.
- static codes(attribute: str) dict[int | None, str] [source]
Returns the codes for the given attribute as defined in the code book.
- title: localized_property[str][source]
- short_title: localized_property[str][source]
- property policy_areas: list[onegov.swissvotes.models.policy_area.PolicyArea][source]
Returns the policy areas / descriptors of the vote.
- property results_cantons: dict[str, list[onegov.swissvotes.models.region.Region]][source]
Returns the results of all cantons.
- get_recommendation_of_existing_parties() dict[str, int] [source]
Get only the existing parties as when this vote was conducted
- group_recommendations(recommendations: collections.abc.Iterable[tuple[T, int | None]], ignore_unknown: bool = False) dict[str, list[T]] [source]
Group the given recommendations by slogan.
- property sorted_actors_list: list[str][source]
Returns a list of actors of the current vote sorted by:
codes for recommendations (strength table)
by electoral share (descending)
It filters out those parties who have no electoral share
- property recommendations_parties: dict[str, list[onegov.swissvotes.models.actor.Actor]][source]
The recommendations of the parties grouped by slogans.
- property recommendations_divergent_parties: dict[str, list[tuple[onegov.swissvotes.models.actor.Actor, onegov.swissvotes.models.region.Region]]][source]
The divergent recommendations of the parties grouped by slogans.
- property recommendations_associations: dict[str, list[onegov.swissvotes.models.actor.Actor]][source]
The recommendations of the associations grouped by slogans.
Returns true, if the vote contains national council share data.
Returns true, if a national council year is set and
- any aggregated national council share data is present (yeas, nays,
none, empty, free vote, neutral, unknown)
- or any national council share data of parties with national council
share and a recommendation regarding this vote is present
- reindex_files() None [source]
Extract the text from the localized files and the campaign material and save it together with the language. Store the text of the indexed only localized files and all campaign material in the search indexes.
The language is determined as follows:
For the localized files, the language is determined by the locale, e.g. de_CH -> german.
For the campaign material, the campaign metadata is used. If a document is (amongst others) de –> german. If (amongst others,) fr but not de –> french. If (amongst others) it but not de or fr –> italian. In all other cases english.
- get_file(name: str, locale: str | None = None, fallback: bool = True) onegov.swissvotes.models.file.SwissVoteFile | None [source]
Returns the requested localized file.
Uses the current locale if no locale is given.
Falls back to the default locale if the file is not available in the requested locale.