{
"info": {
"author": "Andrew P Smith, Tom Russell",
"author_email": "a.p.smith@leeds.ac.uk, tom.russell@ouce.ox.ac.uk",
"bugtrack_url": null,
"classifiers": [
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
"Programming Language :: Python :: 3"
],
"description": "[](https://travis-ci.org/nismod/ukpopulation) [](https://opensource.org/licenses/MIT)\n[](http://joss.theoj.org/papers/269be2c1044e902e2cf7716bc9f0f7c0)\n[](https://zenodo.org/badge/latestdoi/131988266)\n[](https://badge.fury.io/py/ukpopulation)\n[](https://anaconda.org/conda-forge/ukpopulation)\n[](https://anaconda.org/conda-forge/ukpopulation)\n\n\n# ukpopulation: UK Demographic Projections\n\n> ## Latest news: 1.2 release\n> - adds support for custom subnational population projections\n> ### Custom SNPP Data\n> An externally generated SNPP dataset (from e.g. [simim](https://github.com/nismod/simim)) can be registered with the `ukpopulation` package and used as if it was the standard ONS/StatsWales/NRScotland/NISRA projection:\n> ```python3\n> >>> import ukpopulation.customsnppdata as CustomSNPPData\n> >>> customdata = pd.read_csv(\"custom_snpp.csv\")\n> >>> customdata.head()\n> GEOGRAPHY_CODE GENDER C_AGE OBS_VALUE PROJECTED_YEAR_NAME\n> 0 E06000005 1 0 603.0 2018\n> 1 E06000005 1 1 600.0 2018\n> 2 E06000005 1 2 624.0 2018\n> 3 E06000005 1 3 636.0 2018\n> 4 E06000005 1 4 661.0 2018\n> >>> CustomSNPPData.register_custom_projection(\"custom_snpp\", customdata, \"cache_directory\")\n> Writing custom SNPP custom_snpp to cache/ukpopulation_custom_snpp_custom_snpp.csv\n> >>> CustomSNPPData.list_custom_projections(\"cache_directory\")\n> ['custom_snpp']\n> >>>\n> ```\n> The external dataset must follow the format/column name conventions as above, but can also contain extra data if required for other use. The `GENDER` column should only take the values 1 (male) or 2 (female); the `C_AGE` column should contain the range 0-90 inclusive (90 meaning 90 or over).\n\n> ## 1.1 release\n> - adds UK household projections\n> - initial support for custom SNPP variants\n> - better consistency across the MYE/NPP/SNPP APIs (breaks backwards compatibility)\n> - fixes some bugs/issues\n> ### Household Projections\n> Version 1.1 adds functionality is aggregates household projection data for the UK at LAD (or equivalent level). Each country's statistical agency provides a disaggregation by household type, but as there is little or no consistency between them, no attempt has (yet) been made to provide a UK-wide unified disaggregation. The year ranges mirror the year ranges for the SNPP for each country (see below). Extrapolation, or application of a national projection variant to the data is not provided at this stage.\n> ### Custom SNPP Variants\n> Given externally-generated data describing variations to an official projection variant, by geography (LAD) and year, this new functionality generates a full SNPP dataset, disaggregated proportionately by age and gender. The custom variant can optionally be forced to nearest-integer values, preserving the original (rounded) total.\n> ### API consistency\n> The public methods of the `MYEData`, `SNPPData`, `NPPData` and `SNHPData` classes now consistently order arguments: firstly `categories` (where appropriate) then `geogs`, then `years`.\n\nThe statistical agencies of the United Kingdom, that is: [ONS](https://www.ons.gov.uk/), [StatsWales](https://statswales.gov.wales/), [NR Scotland](https://www.nrscotland.gov.uk/), and [NISRA](https://www.nisra.gov.uk/), all produce annual population estimates and projection data. Although the data are essentially the same, the quantity, format, and availability varies between agencies and datasets. All of the population projection data is available by (single year of) age and gender. Household projection data is more varied, with each country/agency producing inconsistent disaggregations of households in terms of HRP age and/or household type. For now, this package does not disaggregate by age and leaves the household type disaggregations as-is, which are:\n\nLowest common denominator | England (ONS) | Wales (StatsWales) | Scotland (NRScotland) | N.Ireland (NISRA) |\n--------------------------|-----------------------------------------------------|--------------------|-----------------------|--------------------|\nSingle person | 'One person households: Female'
'One person households: Male' |'1 person'|'1 adult: female'
'1 adult: male'|'One adult households'|\nAdults and children | 'Households with one dependent child'
'Households with three or more dependent children'
'Households with two dependent children' | '2 person (1 adult, 1 child)'
'3 person (2 adults, 1 child)'
'3 person (1 adult, 2 children)'
'4 person (2+ adults, 1+ children)'
'4 person (1 adult, 3 children)'
'5+ person (2+ adults, 1+ children)'
'5+ person (1 adult, 4+ children)'| '1 adult 1+ children'
'2+ adults 1+ children'| 'One adult households with children'
'Other households with children'|\nAdults only | 'Other households with two or more adults'| '2 person (No children)'
'3 person (No children)'
'4 person (No children)'
'5+ person (No children)'| '2 adults'
'3+ adults'| 'Two adults without children'
'Other households without children'\n\n\nNational population projections (NPP) are the responsibility of ONS who provide the data for each country within the UK, including 15 variants covering a number of possible future scenarios. The current data is based on 2016 population estimates and project a century to 2116.\n\nSubnational population projections (SNPP) are the responsibility of each country's agencies (ONS for England), and project 25 years from a base year that depends on the country in question:\n\nCountry | Latest SNPP year range (as of June 2018) |\n-----------------|------------------------------------------|\nEngland | 2016-2041 |\nWales | 2014-2039 |\nScotland | 2016-2041 |\nNorthern Ireland | 2016-2041 |\n\nMid-year population estimates (MYE) are available for the entire UK by local authority, single year of age and gender, from 1991 to 2016 inclusive.\n\n## Projection Coverage\n\nThe countries within the UK produce their own SNPP data, and also produce some (patchy) variant projections. The ONS currently regard these (the England ones at least) as [\"experimental\"](https://www.ons.gov.uk/peoplepopulationandcommunity/populationandmigration/populationprojections/articles/subnationalpopulationprojectionsresearchreportonvariantprojections/2014basedprojections). \n\nScenario/Variant | Code | E | S | W | N |NPP|\n---------------------------------|------|---|---|---|---|---|\nPrincipal | ppp | x | x | x | x | x |\nHigh fertility | hpp | x | x | | | x |\nLow fertility | lpp | | x | | | x |\nHigh life expectancy | php | | x | | | x |\nLow life expectancy | plp | | x | | | x |\nModerately high life expectancy | pjp | | | | | x |\nModerately low life expectancy | plp | | | | | x |\nHigh migration | pph | | x | | | x |\nLow migration | ppl | | x | | | x |\nHigh population | hhh | | | x | | x |\nLow population | lll | | | x | | x |\n0% future EU migration | ppq | | | | | x |\n50% future EU migration | ppr | | | | | x |\n150% future EU migration | pps | | | | | x |\nZero net migration | ppz | x | x | x | | x |\nYoung age structure | hlh | | | | | |\nOld age structure | lhl | | | | | |\nReplacement fertility | rpp | | | | | |\nConstant fertility | cpp | | | | | |\nNo mortality improvement | pnp | | | | | |\nNo change | cnp | | | | | |\nLong term balanced net migration | ppb | | | x | | |\n\n## Accessibility\n\n[Nomisweb](https://www.nomisweb.co.uk) provides an API which allows relatively easy programmatic access the to data, and by far the preferred source of data. Currently not all the data is available from this source but [this may change](https://www.nomisweb.co.uk/forum/posts.aspx?tID=565&fID=2).\n\nNomisweb currently hosts the ONS principal NPP data for the UK, the SNPP data for England, and all of the MYE data.\n\nAll other data: ONS NPP variants, SNPP data for Wales, Scotland and Northern Ireland are available in different formats from the appropriate agency's website.\n\n# Rationale\n\nThe purpose of this package is to provide a unified interface to both SNPP and NPP data, including variants:\n- encapsulating the downloading, processing and caching of the NPP and SNPP data from the various sources.\n- consistently differentiating by age (single year, up to 90) and gender over the various datasets.\n- providing a unified format for all the data.\n- providing a method of synthesising SNPP variant projections using SNPP principal and NPP principal/variant projections\n- providing a method of extrapolating SNPP data using NPP data\n- enabling easy filtering and aggregating of of the data, e.g. extracting projections of the working-age population.\n\n# Methodology and Detail\n## Data Sources\n- [Nomisweb](https://www.nomisweb.co.uk): UK NPP by country/age/gender, England SNPP by LAD/age/gender, UK MYE by LAD/age/gender.\n- [ONS](https://www.ons.gov.uk): UK NPP variants by country/age/gender.\n- [Stats Wales](http://open.statswales.gov.wales): Wales SNPP by LAD/age/gender.\n- [National Records of Scotland](https://www.nrscotland.gov.uk): Scotland SNPP by LAD equivalent/age/gender.\n- [Northern Ireland Statistics and Research Agency](https://www.nisra.gov.uk): Northern Ireland SNPP by LAD equivalent/age/gender.\n\n## Data Processing\n- Note that the SNPP for each country, and the NPP data may not have the same reference year. (See table above).\n- NPP data is broken down by country (England/Wales/Scotland/Northern Ireland), for all the variant projections indicated in the second table above. \n- Column headings and category values follow the nomisweb/census conventions:\n - `GEOGRAPHY_CODE`: ONS country, LAD, or LAD-equivalent code\n - `GENDER`: 1=Male, 2=Female\n - `C_AGE`: 0-90, where 90 represents 90 or over. To avoid ambiguity, this is an exception - nomisweb census values are typically age+1)\n - `PROJECTED_YEAR_NAME`: 2014-2116 \n - `OBS_VALUE`: count of persons\n- All data are cached for swift retrieval. \n\n# Extrapolation \n\nThe SNPP data can be extrapolated using the longer-term NPP data. This is done independently for each age and gender in order to try to capture the age-gender structure of the original population. Aggregation only takes place on the extrapolated age-gender specific values. This means that the trends shown by SNPP geographies with different age-gender structures will differ.\n\nIf, conversely, the extrapolation was done on the aggregated populations for each SNPP geography, then each SNPP geography would have an identical trend, which would be identical to that of the NPP data.\n\nThis methodology can be more formally explained by the following equation for the aggregate SNPP _S(g,y)_ for a given geography and year:\n\n\n\nwhere _N_ is the NPP, _a_ is age, _s_ is gender, _y bar_ is a reference year (typically the final year in the SNPP data), and _c(g)_ represents a mapping from a SNPP geography (LAD) to a NPP one (country).\n\n# Projection of Variants\n\nThe extrapolation methodology above can equally be applied to synthesising SNPP variants from SNPP principal and NPP variant data. The equivalent expression to the above is:\n\n\n\nwhere the subscripts _V_ and _0_ refer to the variant and the principal projections respectively. \n\n# Installation\n\n## Requirements\n\n### API Key\nThis package uses the [UKCensusAPI](http://github.com/virgesmith/UKCensusAPI) package to obtain some of the projection data. The package requires an API key to function correctly, see [here](https://github.com/virgesmith/UKCensusAPI/blob/master/README.md) for details. \n\n### Package\n\nRequires Python 3.5 or higher. Dependencies *should* resolve automatically, but if not see [troubleshooting](#troubleshooting) \n\n#### PyPI\n\n```bash\n$ python3 -m pip install ukpopulation\n```\n\n#### Conda\n```bash\n$ conda install ukpopulation\n```\nThis assumes you have added the conda-forge channel, which can be done with\n```bash\n$ conda config --add channels conda-forge\n```\n\nSome of the examples (see below) plot graphs and have a dependency on `matplotlib`, which can be installed with either pip or conda as appropriate.\n\n### Development version\n\nTo clone the repo and install locally:\n\n```bash\n$ git clone https://github.com/nismod/ukpopulation\n$ ./setup.py install\n```\n\n(substituting the URL if a fork has been taken). The test data cache directory contains a file `NOMIS_API_KEY` which defines a dummy key for testing purposes only. The test suite can be run from the (project root dir) using:\n\n```bash\n$ ./setup.py test\n```\n\n## Troubleshooting\n\nEnsure you are using the correct version (>=3) of pip:\n\n```bash\n$ pip --version\npip 9.0.1 from /usr/lib/python3/dist-packages (python 3.6)\n```\n\nIf not replace `pip` with `pip3` or `python3 -m pip`\n\nIf the installation has missing dependencies, try:\n```bash\n$ pip install -r requirements.txt\n$ ./setup.py install\n```\n\nIf (with python 3.5?) you encounter \n```bash\nAttributeError: module 'html5lib.treebuilders' has no attribute '_base'\n```\nthen\n```bash\n$ pip install html5lib=0.9999999\n```\nshould fix it. But better solution is to upgrade to python3.6\n\nIf matplotlib fails to install due to a missing dependency (tkinter), this can be fixed on Debian variants by\n\n```bash\n$ sudo apt install python3-tk\n```\n\nIf your problem isn't addressed above, please post an issue including as much supporting information as possible.\n\n# Usage Examples\n\n## Retrieve SNPP for specific LADs\n### Detailed data\nThis example fetches the 2018 projection for Newcastle by gender and age. \n```python\n>>> import ukpopulation.snppdata as SNPPData\n>>> snpp = SNPPData.SNPPData()\n```\n```\nCache directory: ./raw_data/\nusing cached LAD codes: ./raw_data/lad_codes.json\nCollating SNPP data for England...\n./raw_data/NM_2006_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2006_1_56aba41fc0fab32f58ead6ae91a867b4.tsv\n./raw_data/NM_2006_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2006_1_dbe6c087fb46306789f7d54b125482e4.tsv\nCollating SNPP data for Wales...\nCollating SNPP data for Scotland...\nCollating SNPP data for Northern Ireland...\n```\n```python\n>>> newcastle=snpp.filter(\"E08000021\", 2018)\n>>> newcastle.head()\n```\n```\n C_AGE GENDER GEOGRAPHY_CODE OBS_VALUE PROJECTED_YEAR_NAME\n0 0 1 E08000021 1814.0 2018\n1 1 1 E08000021 1780.0 2018\n2 2 1 E08000021 1770.0 2018\n3 3 1 E08000021 1757.0 2018\n4 4 1 E08000021 1747.0 2018\n```\n\n### Aggregated data\nThis example fetches the total population projections for Newcastle from 2018 to 2039.\n```python \n>>> import ukpopulation.snppdata as SNPPData\n>>> snpp = SNPPData.SNPPData()\n```\n```\nCache directory: ./raw_data/\nusing cached LAD codes: ./raw_data/lad_codes.json\nCollating SNPP data for England...\n./raw_data/NM_2006_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2006_1_56aba41fc0fab32f58ead6ae91a867b4.tsv\n./raw_data/NM_2006_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2006_1_dbe6c087fb46306789f7d54b125482e4.tsv\nCollating SNPP data for Wales...\nCollating SNPP data for Scotland...\nCollating SNPP data for Northern Ireland...\n```python\n>>> newcastle=snpp.aggregate([\"GENDER\", \"C_AGE\"], \"E08000021\", range(2018,2039))\n>>> newcastle.head()\n```\n```\n GEOGRAPHY_CODE PROJECTED_YEAR_NAME OBS_VALUE\n0 E08000021 2018 299132.0\n1 E08000021 2019 300530.0\n2 E08000021 2020 301699.0\n3 E08000021 2021 302729.0\n4 E08000021 2022 303896.0\n```\n\n## Retrieve NPP data filtered by age\nHere's how to get the total working-age population by country from 2016 to 2050:\n\n```python\n>>> import ukpopulation.nppdata as NPPData\n>>> npp = NPPData.NPPData()\n```\n```\nCache directory: ./raw_data/\nusing cached LAD codes: ./raw_data/lad_codes.json\nLoading NPP principal (ppp) data for England, Wales, Scotland & Northern Ireland\n./raw_data/NM_2009_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2009_1_444caf1f672f0646722e389963289973.tsv\n```\n```python\n>>> uk_working_age=npp.aggregate([\"GENDER\", \"C_AGE\"], \"ppp\", NPPData.NPPData.UK, range(2016,2051), ages=range(16,75))\n>>> uk_working_age.head()\n GEOGRAPHY_CODE PROJECTED_YEAR_NAME OBS_VALUE\n0 E92000001 2016 40269470\n1 E92000001 2017 40460118\n2 E92000001 2018 40591965\n3 E92000001 2019 40704521\n4 E92000001 2020 40834471\n```\nAnd this aggregates the figures for Great Britain:\n```python\n>>> gb_working_age=npp.aggregate([\"GEOGRAPHY_CODE\", \"GENDER\", \"C_AGE\"], \"ppp\", NPPData.NPPData.GB, range(2016,2051), ages=range(16,75))\n>>> gb_working_age.head()\n PROJECTED_YEAR_NAME OBS_VALUE\n0 2016 46590014\n1 2017 46801693\n2 2018 46944219\n3 2019 47063069\n4 2020 47201882\n```\nNB SNPP data can also be filtered by age and/or gender and/or geography in the same way.\n\n## Retrieve NPP variants for England & Wales\n\nFirst detailed data (by age, gender and country), then aggregated by age and gender.\n\n```python\n>>> import ukpopulation.nppdata as NPPData\n>>> npp=NPPData.NPPData()\nCache directory: ./raw_data/\nusing cached LAD codes: ./raw_data/lad_codes.json\nLoading NPP principal (ppp) data for England, Wales, Scotland & Northern Ireland\n./raw_data/NM_2009_1_metadata.json found, using cached metadata...\nUsing cached data: ./raw_data/NM_2009_1_444caf1f672f0646722e389963289973.tsv\n>>> high_growth = npp.detail(\"hhh\", NPPData.NPPData.EW)\n>>> high_growth.head()\n C_AGE GENDER OBS_VALUE PROJECTED_YEAR_NAME GEOGRAPHY_CODE\n0 0 1 343198 2016 E92000001\n1 0 1 334025 2017 E92000001\n2 0 1 345332 2018 E92000001\n3 0 1 349796 2019 E92000001\n4 0 1 354274 2020 E92000001\n>>> high_growth_agg = npp.aggregate([\"GENDER\", \"C_AGE\"], \"hhh\", NPPData.NPPData.EW)\n>>> high_growth_agg.head()\n GEOGRAPHY_CODE PROJECTED_YEAR_NAME OBS_VALUE\n0 E92000001 2016 55268067\n1 E92000001 2017 55660155\n2 E92000001 2018 56115027\n3 E92000001 2019 56568795\n4 E92000001 2020 57019007\n>>>\n```\n\n## Extrapolate MYE using SNPP and NPP data\n\n### Single Area\n\nConstruct aggregate data for Exeter from 2011-2065:\n- use MYE data up to 2016, aggregated by age and gender.\n- then use SNPP data up to 2041, aggregated by age and gender. \n- extrapolate using NPP data and Exeter's (2041) age-gender structure.\n- aggregrate the extrapolated data by age and gender\n- plot the data. \n\n[Source Code](doc/example_extrapolate.py)\n\n\n\n### Bulk Calculation\n\nIn this example we extrapolate and aggregrate the SNPP for every LAD in Wales:\n- for each area, \n - extrapolate from 2039 to 2050 using the 2039 age-gender structure.\n - aggregate the extrapolated datma by age and gender.\n - append to full dataset.\n- save Wales dataset as csv:\n\n| GEOGRAPHY_CODE | PROJECTED_YEAR_NAME | OBS_VALUE |\n| -------------- | ------------------- | --------- |\n| W06000011 | 2040 | 262903.24103359133 |\n| W06000011 | 2041 | 262933.2340468692 |\n| W06000011 | 2042 | 263162.3661643687 |\n| W06000011 | 2043 | 263332.96819104964 |\n| W06000011 | 2044 | 263593.29826455784 |\n| W06000011 | 2045 | 263923.03553008236 |\n| W06000011 | 2046 | 264243.6253810904 |\n| W06000011 | 2047 | 264168.2113917932 |\n| W06000011 | 2048 | 264211.4576059673 |\n| ... | ... | ... |\n\n[Source Code](doc/example_extrapolate_all.py)\n\n## Construct an SNPP variant by applying NPP variant to a specific LAD\n\nHere we apply the \"hhh\" (high growth) and \"lll\" (low growth) NPP variants to the SNPP data for Newcastle:\n- calculate the principal (\"ppp\") projection by simply aggregrating the SNPP data for Newcastle, 2018-2039, by age and gender.\n- calculate the variants by weighting the unaggregated data (i.e. by age and gender) by the ratio of the NPP variant/principal.\n- aggregrate the variant data by age and gender.\n- plot the results.\n \n[Source Code](doc/example_variant.py)\n\n\n\n## Extrapolating an SNPP variant\n\nHere we build on the examples above by not only applying the NPP variant, but extrapolating too. The process first involves extrapolating the SNPP by the NPP principal variant. The extrapolated data then has the variant adjustments applied to it. \n \n[Source Code](doc/example_variant_ex.py)\n\n\n\n## Comparing household and population projections for a single LAD\n\nIn this example we simply plot the aggregate household projections for Newcastle against the (principal) population projection. You can see that population growth starts to tail off more than the household growth. This suggests a decrease in household size. Further inspection of the data should confirm this.\n\n[Source Code](doc/example_household.py)\n\n\n\n\n# Code Documentation\nPackage documentation can be viewed like so:\n```python\nimport ukpopulation.myedata as MYEData\nhelp(MYEData)\nimport ukpopulation.nppdata as NPPData\nhelp(NPPData)\nimport ukpopulation.snppdata as SNPPData\nhelp(SNPPData)\nimport ukpopulation.snhpdata as SNHPData\nhelp(SNHPData)\n```\n\n# Contributions\n\nContributions to this package are welcomed via the usual pull request mechanism.\n\n# Support\n\nIf you encounter a bug, feel the documentation is incorrect or incomplete, or want to suggest new features, please post an issue in the [issues](https://github.com/nismod/ukpopulation/issues) tab. \n\n# Acknowledgements\nThis package was developed as a component of the EPSRC-funded [MISTRAL](https://www.itrc.org.uk/) programme, part of the Infrastructure Transitions Research Consortium.",
"description_content_type": "text/markdown",
"docs_url": null,
"download_url": "",
"downloads": {
"last_day": -1,
"last_month": -1,
"last_week": -1
},
"home_page": "https://github.com/nismod/ukpopulation",
"keywords": "",
"license": "",
"maintainer": "",
"maintainer_email": "",
"name": "ukpopulation",
"package_url": "https://pypi.org/project/ukpopulation/",
"platform": "",
"project_url": "https://pypi.org/project/ukpopulation/",
"project_urls": {
"Homepage": "https://github.com/nismod/ukpopulation"
},
"release_url": "https://pypi.org/project/ukpopulation/1.2.1/",
"requires_dist": null,
"requires_python": "",
"summary": "Download, cache, collate, filter, manipulate and extrapolate UK population and household estimates/projections",
"version": "1.2.1"
},
"last_serial": 5400422,
"releases": {
"1.0.2": [
{
"comment_text": "",
"digests": {
"md5": "4f208718a731f6691906aa72c92c2fdd",
"sha256": "b29023d437ca391b89fd227cbc106f0147c6f9fddcd2995d030f03da0161758a"
},
"downloads": -1,
"filename": "ukpopulation-1.0.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "4f208718a731f6691906aa72c92c2fdd",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 18254,
"upload_time": "2018-07-16T13:19:41",
"url": "https://files.pythonhosted.org/packages/ae/98/128def269554ecad9ab080c3808102c8dee45b41e7aa68d24300e994871f/ukpopulation-1.0.2-py3-none-any.whl"
},
{
"comment_text": "",
"digests": {
"md5": "c2d84454d8e874bd145083cb51d8ee38",
"sha256": "fa196fe73a9c61b7457d666e20c3a1840d2d5831cdf22ae8986c9eee2c9a9a49"
},
"downloads": -1,
"filename": "ukpopulation-1.0.2.tar.gz",
"has_sig": false,
"md5_digest": "c2d84454d8e874bd145083cb51d8ee38",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 24804,
"upload_time": "2018-07-16T13:19:42",
"url": "https://files.pythonhosted.org/packages/67/5b/6055c2bcaebbc6acc009c1df7113089b247fe2beebd03e00b96c9e913f48/ukpopulation-1.0.2.tar.gz"
}
],
"1.0.3": [
{
"comment_text": "",
"digests": {
"md5": "5f96c9aed98bafc27813900609878258",
"sha256": "74745f4170eebdabc43f7ff755a9fb81007b789be19f184ccc08794a5b5bee2f"
},
"downloads": -1,
"filename": "ukpopulation-1.0.3-py3.6.egg",
"has_sig": false,
"md5_digest": "5f96c9aed98bafc27813900609878258",
"packagetype": "bdist_egg",
"python_version": "3.6",
"requires_python": null,
"size": 32203,
"upload_time": "2018-07-17T13:53:01",
"url": "https://files.pythonhosted.org/packages/3e/dd/cb8e6e53f98ae0f43448ce493575d1493dc9b0e302c7f88f1fffaa5e0f47/ukpopulation-1.0.3-py3.6.egg"
},
{
"comment_text": "",
"digests": {
"md5": "2396b78caec36b96756b4a8fec70e1f3",
"sha256": "b11827651e44d950484d6a5c57778f43971cab64eb7fe1b4f315e7d5f4a0668a"
},
"downloads": -1,
"filename": "ukpopulation-1.0.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "2396b78caec36b96756b4a8fec70e1f3",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 18562,
"upload_time": "2018-07-17T13:53:00",
"url": "https://files.pythonhosted.org/packages/93/c4/14dc2643d441f39e30daf69f4bd5cfe96e74b0cf2b3f9e2b477120c33748/ukpopulation-1.0.3-py3-none-any.whl"
},
{
"comment_text": "",
"digests": {
"md5": "61c155c56894378a4f7ffd0d3621433d",
"sha256": "8c2320796285e011cf93ffcc14f822ffe6dc4102b8fa4ecc9b44a7b788442904"
},
"downloads": -1,
"filename": "ukpopulation-1.0.3.tar.gz",
"has_sig": false,
"md5_digest": "61c155c56894378a4f7ffd0d3621433d",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 26304,
"upload_time": "2018-07-17T13:53:03",
"url": "https://files.pythonhosted.org/packages/06/4e/bd7d79d83a0b5535dabfec2bc245bec1a30cf918c4dd2bba336a3c4d1a7c/ukpopulation-1.0.3.tar.gz"
}
],
"1.1.0": [
{
"comment_text": "",
"digests": {
"md5": "c8dd4fdd6d3ee8ca562fd4cec4a985a8",
"sha256": "7e40134bdd4cb7e5bdd80340c64378d31cc7f2d2680e488602df60d25fbac006"
},
"downloads": -1,
"filename": "ukpopulation-1.1.0-py3.6.egg",
"has_sig": false,
"md5_digest": "c8dd4fdd6d3ee8ca562fd4cec4a985a8",
"packagetype": "bdist_egg",
"python_version": "3.6",
"requires_python": null,
"size": 44066,
"upload_time": "2019-01-11T14:18:48",
"url": "https://files.pythonhosted.org/packages/f6/68/7459230f149a658c7dd2052313b25bc0ce4655ea5a1ada09e1919ad4a180/ukpopulation-1.1.0-py3.6.egg"
},
{
"comment_text": "",
"digests": {
"md5": "2935ef46f687b49c160343cdaaf51c32",
"sha256": "5d37c8260ca605d5ea1c5932d54830ece7f9027da5e1e3b4b4a52a16e8d549c4"
},
"downloads": -1,
"filename": "ukpopulation-1.1.0.tar.gz",
"has_sig": false,
"md5_digest": "2935ef46f687b49c160343cdaaf51c32",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 31131,
"upload_time": "2019-01-11T14:18:50",
"url": "https://files.pythonhosted.org/packages/6e/cb/2b44e038029ff266e531618f2e54e706e26271b1ca7ee7226db5993ee17e/ukpopulation-1.1.0.tar.gz"
}
],
"1.1.1": [
{
"comment_text": "",
"digests": {
"md5": "f6001d40491cdd4b4b291fa91e2ec438",
"sha256": "90e9bd631bff7bbefb5bbe62c6dd0a18ea8c3d6d87c1b1f0d264514927d33dd1"
},
"downloads": -1,
"filename": "ukpopulation-1.1.1-py3.6.egg",
"has_sig": false,
"md5_digest": "f6001d40491cdd4b4b291fa91e2ec438",
"packagetype": "bdist_egg",
"python_version": "3.6",
"requires_python": null,
"size": 44295,
"upload_time": "2019-03-01T14:15:57",
"url": "https://files.pythonhosted.org/packages/85/24/d0d4be556c870a254caa0849d991dcb8a1e574812b9718818da5c474a4a3/ukpopulation-1.1.1-py3.6.egg"
},
{
"comment_text": "",
"digests": {
"md5": "b1d00c41cbaeea1b70deb8b31f6468b0",
"sha256": "e5f412182b4b2f0db899c7b6551d9d5b01f825dfbd25ea02f85488efbe4526f3"
},
"downloads": -1,
"filename": "ukpopulation-1.1.1.tar.gz",
"has_sig": false,
"md5_digest": "b1d00c41cbaeea1b70deb8b31f6468b0",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 31809,
"upload_time": "2019-03-01T14:15:59",
"url": "https://files.pythonhosted.org/packages/1c/d5/6bc53b5aa64204a2eeb285ef07b67257c48be157143183b8f7054adc3e57/ukpopulation-1.1.1.tar.gz"
}
],
"1.1.3": [
{
"comment_text": "",
"digests": {
"md5": "3b74afe1572b89a41c6dff09d16eeac2",
"sha256": "0091a937815de2b8179ce74219dcf2aa965ca19a0ac9f8ead35e9f5d668fbc2c"
},
"downloads": -1,
"filename": "ukpopulation-1.1.3.tar.gz",
"has_sig": false,
"md5_digest": "3b74afe1572b89a41c6dff09d16eeac2",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 31638,
"upload_time": "2019-04-05T21:07:18",
"url": "https://files.pythonhosted.org/packages/c8/81/31afed96ffad2196e69489dd8f79abd44e9a312646c0b893b5b702952a8e/ukpopulation-1.1.3.tar.gz"
}
],
"1.2.0": [
{
"comment_text": "",
"digests": {
"md5": "31f6d82153f8cc02390d124369865c99",
"sha256": "066d31889a40457edbdc79f4424005193a517c31b61160fb3ed9b110fd725d79"
},
"downloads": -1,
"filename": "ukpopulation-1.2.0.tar.gz",
"has_sig": false,
"md5_digest": "31f6d82153f8cc02390d124369865c99",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 33762,
"upload_time": "2019-06-06T10:04:22",
"url": "https://files.pythonhosted.org/packages/61/f7/efb6e31bfdffdfd7d25e6155c813c96bcc71a803281349dc66dd15a5c1b2/ukpopulation-1.2.0.tar.gz"
}
],
"1.2.1": [
{
"comment_text": "",
"digests": {
"md5": "441cb37805e1e5467aa5863abd04c0ed",
"sha256": "c3e67cfe04e5b8e56e4f51f9c198543ff6f8e75d355d7bdac279666b4cb66bb4"
},
"downloads": -1,
"filename": "ukpopulation-1.2.1.tar.gz",
"has_sig": false,
"md5_digest": "441cb37805e1e5467aa5863abd04c0ed",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 35824,
"upload_time": "2019-06-14T12:46:31",
"url": "https://files.pythonhosted.org/packages/40/68/8d1ae9e2cb6b124fb36be65c9c5bc87e59d43a1a108fa9d6419795f42a3e/ukpopulation-1.2.1.tar.gz"
}
]
},
"urls": [
{
"comment_text": "",
"digests": {
"md5": "441cb37805e1e5467aa5863abd04c0ed",
"sha256": "c3e67cfe04e5b8e56e4f51f9c198543ff6f8e75d355d7bdac279666b4cb66bb4"
},
"downloads": -1,
"filename": "ukpopulation-1.2.1.tar.gz",
"has_sig": false,
"md5_digest": "441cb37805e1e5467aa5863abd04c0ed",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 35824,
"upload_time": "2019-06-14T12:46:31",
"url": "https://files.pythonhosted.org/packages/40/68/8d1ae9e2cb6b124fb36be65c9c5bc87e59d43a1a108fa9d6419795f42a3e/ukpopulation-1.2.1.tar.gz"
}
]
}