country-converter


Namecountry-converter JSON
Version 1.2 PyPI version JSON
download
home_page
SummaryThe country converter (coco) - a Python package for converting country names between different classifications schemes
upload_time2023-12-12 20:12:30
maintainer
docs_urlNone
author
requires_python>=3.7
licenseGNU General Public License v3 (GPLv3)
keywords country iso 3166
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            # country converter

The country converter (coco) is a Python package to convert and match
country names between different classifications and between different
naming versions. Internally it uses regular expressions to match country
names. Coco can also be used to build aggregation concordance matrices
between different classification schemes.

[![image](https://img.shields.io/pypi/v/country-converter.svg)](https://pypi.python.org/pypi/country_converter/)
[![image](https://anaconda.org/conda-forge/country_converter/badges/version.svg)](https://anaconda.org/conda-forge/country_converter)
[![image](https://zenodo.org/badge/DOI/10.5281/zenodo.838035.svg)](https://doi.org/10.5281/zenodo.838035)
[![image](http://joss.theoj.org/papers/af694f2e5994b8aacbad119c4005e113/status.svg)](http://joss.theoj.org/papers/af694f2e5994b8aacbad119c4005e113)

[![image](https://github.com/IndEcol/country_converter/workflows/build/badge.svg)](https://github.com/IndEcol/country_converter/actions)
[![image](https://coveralls.io/repos/github/IndEcol/country_converter/badge.svg?branch=master&service=github)](https://coveralls.io/github/IndEcol/country_converter?branch=master)
[![image](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![image](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)


## Motivation

To date, there is no single standard of how to name or specify
individual countries in a (meta) data description. While some data
sources follow ISO 3166, this standard defines a two and a three letter
code in addition to a numerical classification. To further complicate
the matter, instead of using one of the existing standards, many
databases use unstandardised country names to classify countries.

The country converter (coco) automates the conversion from different
standards and version of country names. Internally, coco is based on a
table specifying the different ISO and UN standards per country together
with the official name and a regular expression which aim to match all
English versions of a specific country name. In addition, coco includes
classification based on UN-, EU-, OECD-membership, UN regions
specifications, continents and various MRIO and IAM databases (see
[Classification schemes](#classification-schemes) below).

## Installation

Country_converter is registered at PyPI. From the command line:

    pip install country_converter --upgrade

The country converter is also available from the [conda
forge](https://conda-forge.org/) and can be installed using conda with
(if you don't have the conda_forge channel added to your conda config
add "-c conda-forge", see [the install instructions
here](https://github.com/conda-forge/country_converter-feedstock)):

    conda install country_converter

Alternatively, the source code is available on
[GitHub](https://github.com/IndEcol/country_converter).

The package depends on [Pandas](http://pandas.pydata.org/); for testing
[pytest](http://pytest.org/) is required. For further information on
running the tests see [CONTRIBUTING.md](CONTRIBUTING.md).

## Usage

### Basic usage

#### Use within Python

Convert various country names to some standard names:

``` python
import country_converter as coco
some_names = ['United Rep. of Tanzania', 'DE', 'Cape Verde', '788', 'Burma', 'COG',
              'Iran (Islamic Republic of)', 'Korea, Republic of',
              "Dem. People's Rep. of Korea"]
standard_names = coco.convert(names=some_names, to='name_short')
print(standard_names)
```

Which results in \['Tanzania', 'Germany', 'Cabo Verde', 'Tunisia',
'Myanmar', 'Congo Republic', 'Iran', 'South Korea', 'North Korea'\]. The
input format is determined automatically, based on ISO two letter, ISO
three letter, ISO numeric or regular expression matching. In case of any
ambiguity, the source format can be specified with the parameter 'src'.

In case of multiple conversion, better performance can be achieved by
instantiating a single CountryConverter object for all conversions:

``` python
import country_converter as coco
cc = coco.CountryConverter()

some_names = ['United Rep. of Tanzania', 'Cape Verde', 'Burma',
              'Iran (Islamic Republic of)', 'Korea, Republic of',
              "Dem. People's Rep. of Korea"]

standard_names = cc.convert(names = some_names, to = 'name_short')
UNmembership = cc.convert(names = some_names, to = 'UNmember')
print(standard_names)
print(UNmembership)
```

In order to more efficiently convert Pandas Series, the `pandas_convert()` method can be used. The
performance gain is especially significant for large Series. For a series containing 1 million rows
a 4000x speedup can be achieved, compared to `convert()`.

``` python
import country_converter as coco
import pandas as pd
cc = coco.CountryConverter()

some_countries = pd.Series(['Australia', 'Belgium', 'Brazil', 'Bulgaria', 'Cyprus', 'Czech Republic',
                  'Guatemala', 'Mexico', 'Honduras', 'Costa Rica', 'Colombia', 'Greece', 'Hungary',
                  'India', 'Indonesia', 'Ireland', 'Italy', 'Japan', 'Latvia', 'Lithuania',
                  'Luxembourg', 'Malta', 'Jamaica', 'Ireland', 'Turkey', 'United Kingdom',
                  'United States'], name='country')
 
iso3_codes = cc.pandas_convert(series=some_countries, to='ISO3')                  
```

Convert between classification schemes:

``` python
iso3_codes = ['USA', 'VUT', 'TKL', 'AUT', 'XXX' ]
iso2_codes = coco.convert(names=iso3_codes, to='ISO2')
print(iso2_codes)
```

Which results in \['US', 'VU', 'TK', 'AT', 'not found'\]

The not found indication can be specified (e.g. not_found = 'not
there'), if None is passed for 'not_found', the original entry gets
passed through:

``` python
iso2_codes = coco.convert(names=iso3_codes, to='ISO2', not_found=None)
print(iso2_codes)
```

results in \['US', 'VU', 'TK', 'AT', 'XXX'\]

Internally the data is stored in a Pandas DataFrame, which can be
accessed directly. For example, this can be used to filter countries for
membership organisations (per year). Note: for this, an instance of
CountryConverter is required.

``` python
import country_converter as coco
cc = coco.CountryConverter()

some_countries = ['Australia', 'Belgium', 'Brazil', 'Bulgaria', 'Cyprus', 'Czech Republic',
                  'Denmark', 'Estonia', 'Finland', 'France', 'Germany', 'Greece', 'Hungary',
                  'India', 'Indonesia', 'Ireland', 'Italy', 'Japan', 'Latvia', 'Lithuania',
                  'Luxembourg', 'Malta', 'Romania', 'Russia', 'Turkey', 'United Kingdom',
                  'United States']

oecd_since_1995 = cc.data[(cc.data.OECD >= 1995) & cc.data.name_short.isin(some_countries)].name_short
eu_until_1980 = cc.data[(cc.data.EU <= 1980) & cc.data.name_short.isin(some_countries)].name_short
print(oecd_since_1995)
print(eu_until_1980)
```

All classifications can be directly accessed by:

``` python
cc.EU28
cc.OECD

cc.EU27as('ISO3')
```

and the classification schemes available:

``` python
cc.valid_class
```

There is also a methdod for only getting country classifications (thus
omitting any grouping of countries):

``` python
cc.valid_country_classifications
```

If you rather need a dictionary describing the classification/membership
use:

``` python
import country_converter as coco
cc = coco.CountryConverter()
cc.get_correspondence_dict('EXIO3', 'ISO3')
```

to also include countries not assigned within a specific classification
use:

``` python
cc.get_correspondence_dict('EU27', 'ISO2', replace_nan='NonEU')
```

The regular expressions can also be used to match any list of countries
to any other. For example:

``` python
match_these = ['norway', 'united_states', 'china', 'taiwan']
master_list = ['USA', 'The Swedish Kingdom', 'Norway is a Kingdom too',
               'Peoples Republic of China', 'Republic of China' ]

matching_dict = coco.match(match_these, master_list)
```

Country converter by default provides a warning to the python <span
class="title-ref">logging</span> logger if no match is found. The
following example demonstrates how to configure the <span
class="title-ref">coco</span> logging behaviour.

``` python
import logging
import country_converter as coco
logging.basicConfig(level=logging.INFO)
coco.convert("asdf")
# WARNING:country_converter.country_converter:asdf not found in regex
# Out: 'not found'

coco_logger = coco.logging.getLogger()
coco_logger.setLevel(logging.CRITICAL)
coco.convert("asdf")
# Out: 'not found'
```

See the IPython Notebook
([country_converter_examples.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_examples.ipynb))
for more information.

#### Command line usage

The country converter package also provides a command line interface
called coco.

Minimal example:

    coco Cyprus DE Denmark Estonia 4 'United Kingdom' AUT

Converts the given names to ISO3 codes based on matching the input to
ISO2, ISO3, ISOnumeric or regular expression matching. The list of names
must be separated by spaces, country names consisting of multiple words
must be put in quotes ('').

The input classification can be specified with '--src' or '-s' (or will
be determined automatically), the target classification with '--to' or
'-t'.

The default output is a space separated list, this can be changed by
passing a separator by '--output_sep' or '-o' (e.g -o '\|').

Thus, to convert from ISO3 to UN number codes and receive the output as
comma separated list use:

    coco AUT DEU VAT AUS -s ISO3 -t UNcode -o ', '

The command line tool also allows to specify the output for none found
entries, including passing them through to the output by passing None:

    coco CAN Peru US Mexico Venezuela UK Arendelle --not_found=None

and to specify an additional data file which will overwrite existing
country matching

    coco Congo --additional_data path/to/datafile.csv

See
<https://github.com/IndEcol/country_converter/tree/master/tests/custom_data_example.txt>
for an example of an additional datafile.

The flags --UNmember_only (-u) and --include_obsolete (-i) restrict the
search to UN member states only or extend it to also include currently
obsolete countries. For example, the [Netherlands
Antilles](https://en.wikipedia.org/wiki/Netherlands_Antilles) were
dissolved in 2010.

Thus:

    coco "Netherlands Antilles"

results in "not found". The search, however, can be extended to recently
dissolved countries by:

    coco "Netherlands Antilles" -i

which results in 'ANT'.

In addition to the countries, the coco command line tool also accepts
various country classifications (EXIO1, EXIO2, EXIO3, WIOD, Eora,
MESSAGE, OECD, EU27, EU28, UN, obsolete, Cecilia2050, BRIC, APEC, BASIC,
CIS, G7, G20). One of these can be passed by

    coco G20

which lists all countries in that classification.

For the classifications covering almost all countries (MRIO and IAM
classifications)

    coco EXIO3

lists the unique classification names. When passing a --to parameter, a
simplified correspondence of the chosen classification is printed:

    coco EXIO3 --to ISO3

For further information call the help by

    coco -h

#### Use in Matlab

Newer (tested in 2016a) versions of Matlab allow to directly call Python
functions and libraries. This requires a Python version \>= 3.4
installed in the system path (e.g. through Anaconda).

To test, try this in Matlab:

``` matlab
py.print(py.sys.version)
```

If this works, you can also use coco after installing it through pip (at
the windows commandline - see the installing instruction above):

``` matlab
pip install country_converter --upgrade
```

And in matlab:

``` matlab
coco = py.country_converter.CountryConverter()
countries = {'The Swedish Kingdom', 'Norway is a Kingdom too', 'Peoples Republic of China', 'Republic of China'};
ISO2_pythontype = coco.convert(countries, pyargs('to', 'ISO2'));
ISO2_cellarray = cellfun(@char,cell(ISO2_pythontype),'UniformOutput',false);
```

Alternatively, as a long oneliner:

``` matlab
short_names = cellfun(@char, cell(py.country_converter.convert({56, 276}, pyargs('src', 'UNcode', 'to', 'name_short'))), 'UniformOutput',false);
```

All properties of coco as explained above are also available in Matlab:

``` matlab
coco = py.country_converter.CountryConverter();
coco.EU27
EU27ISO3 = coco.EU27as('ISO3');
```

These functions return a Pandas DataFrame. The underlying values can be
access with .values (e.g.

``` matlab
EU27ISO3.values
```

I leave it to professional Matlab users to figure out how to further
process them.

See also IPython Notebook
([country_converter_examples.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_examples.ipynb))
for more information - all functions available in Python (for example
passing additional data files, specifying the output in case of missing
data) work also in Matlab by passing arguments through the pyargs
function.

### Building concordances for country aggregation

Coco provides a function for building concordance vectors, matrices and
dictionaries between different classifications. This can be used in
python as well as in matlab. For further information see
([country_converter_aggregation_helper.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_aggregation_helper.ipynb))

## Classification schemes

Currently the following classification schemes are available (see also
Data sources below for further information):

1.  ISO2 (ISO 3166-1 alpha-2) - including UK/EL for Britain/Greece (but always convert to GB/GR)
2.  ISO3 (ISO 3166-1 alpha-3)
3.  ISO - numeric (ISO 3166-1 numeric)
4.  UN numeric code (M.49 - follows to a large extend ISO-numeric)
5.  A standard or short name
6.  The "official" name
7.  Continent: 6 continent classification with Africa, Antarctica, Asia, Europe, America, Oceania
8.  [Continent_7 classification](https://ourworldindata.org/world-region-map-definitions) - 7 continent classification spliting North/South America
9.  UN region
10. [EXIOBASE 1](http://exiobase.eu/) classification (2 and 3 letters)
11. [EXIOBASE 2](http://exiobase.eu/) classification (2 and 3 letters)
12. [EXIOBASE 3](https://zenodo.org/doi/10.5281/zenodo.3583070) classification (2 and 3 letters)
13. [WIOD](http://www.wiod.org/home) classification
14. [Eora](http://www.worldmrio.com/)
15. [OECD](http://www.oecd.org/about/membersandpartners/list-oecd-member-countries.htm)
    membership (per year)
16. [MESSAGE](http://www.iiasa.ac.at/web/home/research/researchPrograms/Energy/MESSAGE-model-regions.en.html)
    11-region classification
17. [IMAGE](https://models.pbl.nl/image/index.php/Welcome_to_IMAGE_3.0_Documentation)
18. [REMIND](https://www.pik-potsdam.de/en/institute/departments/transformation-pathways/models/remind)
19. [UN](http://www.un.org/en/members/) membership (per year)
20. [EU](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements)
    membership (including EU12, EU15, EU25, EU27, EU27_2007, EU28)
21. [EEA](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:European_Economic_Area_(EEA))
    membership
22. [Schengen](https://en.wikipedia.org/wiki/Schengen_Area) region
23. [Cecilia](https://cecilia2050.eu/system/files/De%20Koning%20et%20al.%20%282014%29_Scenarios%20for%202050_0.pdf)
    2050 classification
24. [APEC](https://en.wikipedia.org/wiki/Asia-Pacific_Economic_Cooperation)
25. [BRIC](https://en.wikipedia.org/wiki/BRIC)
26. [BASIC](https://en.wikipedia.org/wiki/BASIC_countries)
27. [CIS](https://en.wikipedia.org/wiki/Commonwealth_of_Independent_States)
    (as by 2019, excl. Turkmenistan)
28. [G7](https://en.wikipedia.org/wiki/Group_of_Seven)
29. [G20](https://en.wikipedia.org/wiki/G20) (listing all EU member
    states as individual members)
30. [FAOcode](http://www.fao.org/faostat/en/#definitions) (numeric)
31. [GBDcode](http://ghdx.healthdata.org/) (numeric - Global Burden of
    Disease country codes)
32. [IEA](https://www.iea.org/countries) (World Energy Balances 2021)
33. [DACcode](https://www.oecd.org/dac/financing-sustainable-development/development-finance-standards/dacandcrscodelists.htm)
    (numeric - OECD Development Assistance Committee)
33. [ccTLD](https://en.wikipedia.org/wiki/Country_code_top-level_domain) - country code top-level domains
34. [GWcode](https://www.tandfonline.com/doi/abs/10.1080/03050629908434958) - Gledisch & Ward numerical codes as published in https://www.andybeger.com/states/articles/statelists.html
35. CC41 - common classification for MRIOs (list of countries found in all public MRIOs)
36. [IOC](https://en.wikipedia.org/wiki/List_of_IOC_country_codes) - International Olympic Committee (IOC) country codes


Coco contains official recognised codes as well as non-standard codes
for disputed or dissolved countries. To restrict the set to only the
official recognized UN members or include obsolete countries, pass

``` python
import country_converter as coco
cc = coco.CountryConverter()
cc_UN = coco.CountryConverter(only_UNmember=True)
cc_all = coco.CountryConverter(include_obsolete=True)

cc.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')
cc_UN.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')
cc_all.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')
```

cc results in \['Palestine', 'Kosovo', 'not found', 'France'\], whereas
cc_UN converts to \['not found', 'not found', 'not found', 'France'\]
and cc_all converts to \['Palestine', 'Kosovo', 'Zanzibar', 'France'\]
Note that the underlying dataframe is available at the attribute .data
(e.g. cc_all.data).

## Data sources and further reading

Most of the underlying data can be found in Wikipedia, the page describing [ISO
3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) is a good starting point. The
page on the [ISO2 codes](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)
includes a section "Imperfect Implementations" explaining the GB/UK and EL/GR
issue.
UN regions/codes are given on the United Nation
Statistical Division
([unstats](http://unstats.un.org/unsd/methods/m49/m49regin.htm))
webpage. The differences between the ISO numeric and UN (M.49) codes are
[also explained at wikipedia](https://en.wikipedia.org/wiki/UN_M.49).
[EXIOBASE](http://exiobase.eu/), [WIOD](http://www.wiod.org/home) and
[Eora](http://www.worldmrio.com/) classification were extracted from the
respective databases. For [Eora](http://www.worldmrio.com/), the names
are based on the 'Country names' csv file provided on the webpage, but
updated for different names used in the Eora26 database. The MESSAGE
classification follows the 11-region aggregation given in the
[MESSAGE](http://www.iiasa.ac.at/web/home/research/researchPrograms/Energy/MESSAGE-model-regions.en.html)
model regions description. The
[IMAGE](https://models.pbl.nl/image/index.php/Welcome_to_IMAGE_3.0_Documentation)
classification is based on the "[region classification
map](https://models.pbl.nl/image/index.php/Region_classification_map)",
for
[REMIND](https://www.pik-potsdam.de/en/institute/departments/transformation-pathways/models/remind)
we received a country mapping from the model developers.

The membership of
[OECD](http://www.oecd.org/about/membersandpartners/list-oecd-member-countries.htm)
and [UN](http://www.un.org/en/members/) can be found at the membership
organisations' webpages, information about obsolete country codes on the
[Statoids](http://www.statoids.com/w3166his.html) webpage.

The situation for the
[EU](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements)
got complicated due to the Brexit process. For the naming, coco follows
the [Eurostat
glossary](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements),
thus EU27 refers to the EU without UK, whereas EU27_2007 refers to the
EU without Croatia (the status after the 2007 enlargement). The shortcut
EU always links to the most recent classification. The
[EEA](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:European_Economic_Area_(EEA))
agreements for the UK ended by 2021-01-01 (which also affects Guernsey, Isle of Man, Jersey and Gibraltar). 
Switzerland is not part of the EEA but member of the single market.

The Global Burden of Disease country codes were extracted form the [GBD
code book available
here.](https://ghdx.healthdata.org/sites/default/files/ihme_query_tool/IHME_GBD_2019_CODEBOOK.zip)

## Communication, issues, bugs and enhancements

Please use the issue tracker for documenting bugs, proposing
enhancements and all other communication related to coco.

You can follow me on [mastodon - @kst@qoto.org](https://qoto.org/@kst) and [twitter](https://twitter.com/kst_stadler) to get
the latest news about all my open-source and research projects (and
occasionally some random retweets/toots).

## Contributing

Want to contribute? Great! Please check
[CONTRIBUTING.md](CONTRIBUTING.md) if you want to help to improve coco
and for some pointer for how to add classifications.

## Related software

The package [pycountry](https://pypi.python.org/pypi/pycountry) provides
access to the official ISO databases for historic countries, country
subdivisions, languages and currencies. In case you need to convert
non-English country names,
[countrynames](https://github.com/occrp/countrynames) includes an
extensive database of country names in different languages and functions
to convert them to the different ISO 3166 standards.
[Python-iso3166](https://github.com/deactivated/python-iso3166) focuses
on conversion between the two-letter, three-letter and three-digit codes
defined in the ISO 3166 standard.

If you are using R, you should have a look at
[countrycode](https://github.com/vincentarelbundock/countrycode).

## Citing the country converter

Version 0.5 of the country converter was published in the [Journal of
Open Source Software](http://joss.theoj.org/). To cite the country
converter in publication please use:

Stadler, K. (2017). The country converter coco - a Python package for
converting country names between different classification schemes. The
Journal of Open Source Software. doi:
[10.21105/joss.00332](http://dx.doi.org/10.21105/joss.00332)

For the full bibtex key see [CITATION](CITATION)

## Acknowledgements

This package was inspired by (and the regular expression are mostly
based on) the R-package
[countrycode](https://github.com/vincentarelbundock/countrycode) by
[Vincent Arel-Bundock](http://arelbundock.com/) and his (defunct) port
to Python (pycountrycode). Many thanks to [Robert
Gieseke](https://github.com/rgieseke) for the review of the source code
and paper for the publication in the [Journal of Open Source
Software](http://joss.theoj.org/).

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "country-converter",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": "",
    "keywords": "country,ISO 3166",
    "author": "",
    "author_email": "Konstantin Stadler <konstantin.stadler@ntnu.no>",
    "download_url": "https://files.pythonhosted.org/packages/ff/86/7f33a4394b882ba4a2c6eb08cc71a4c2dc616ca3bdd622db0cbdfea13fe8/country_converter-1.2.tar.gz",
    "platform": null,
    "description": "# country converter\n\nThe country converter (coco) is a Python package to convert and match\ncountry names between different classifications and between different\nnaming versions. Internally it uses regular expressions to match country\nnames. Coco can also be used to build aggregation concordance matrices\nbetween different classification schemes.\n\n[![image](https://img.shields.io/pypi/v/country-converter.svg)](https://pypi.python.org/pypi/country_converter/)\n[![image](https://anaconda.org/conda-forge/country_converter/badges/version.svg)](https://anaconda.org/conda-forge/country_converter)\n[![image](https://zenodo.org/badge/DOI/10.5281/zenodo.838035.svg)](https://doi.org/10.5281/zenodo.838035)\n[![image](http://joss.theoj.org/papers/af694f2e5994b8aacbad119c4005e113/status.svg)](http://joss.theoj.org/papers/af694f2e5994b8aacbad119c4005e113)\n\n[![image](https://github.com/IndEcol/country_converter/workflows/build/badge.svg)](https://github.com/IndEcol/country_converter/actions)\n[![image](https://coveralls.io/repos/github/IndEcol/country_converter/badge.svg?branch=master&service=github)](https://coveralls.io/github/IndEcol/country_converter?branch=master)\n[![image](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n[![image](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)\n\n\n## Motivation\n\nTo date, there is no single standard of how to name or specify\nindividual countries in a (meta) data description. While some data\nsources follow ISO 3166, this standard defines a two and a three letter\ncode in addition to a numerical classification. To further complicate\nthe matter, instead of using one of the existing standards, many\ndatabases use unstandardised country names to classify countries.\n\nThe country converter (coco) automates the conversion from different\nstandards and version of country names. Internally, coco is based on a\ntable specifying the different ISO and UN standards per country together\nwith the official name and a regular expression which aim to match all\nEnglish versions of a specific country name. In addition, coco includes\nclassification based on UN-, EU-, OECD-membership, UN regions\nspecifications, continents and various MRIO and IAM databases (see\n[Classification schemes](#classification-schemes) below).\n\n## Installation\n\nCountry_converter is registered at PyPI. From the command line:\n\n    pip install country_converter --upgrade\n\nThe country converter is also available from the [conda\nforge](https://conda-forge.org/) and can be installed using conda with\n(if you don't have the conda_forge channel added to your conda config\nadd \"-c conda-forge\", see [the install instructions\nhere](https://github.com/conda-forge/country_converter-feedstock)):\n\n    conda install country_converter\n\nAlternatively, the source code is available on\n[GitHub](https://github.com/IndEcol/country_converter).\n\nThe package depends on [Pandas](http://pandas.pydata.org/); for testing\n[pytest](http://pytest.org/) is required. For further information on\nrunning the tests see [CONTRIBUTING.md](CONTRIBUTING.md).\n\n## Usage\n\n### Basic usage\n\n#### Use within Python\n\nConvert various country names to some standard names:\n\n``` python\nimport country_converter as coco\nsome_names = ['United Rep. of Tanzania', 'DE', 'Cape Verde', '788', 'Burma', 'COG',\n              'Iran (Islamic Republic of)', 'Korea, Republic of',\n              \"Dem. People's Rep. of Korea\"]\nstandard_names = coco.convert(names=some_names, to='name_short')\nprint(standard_names)\n```\n\nWhich results in \\['Tanzania', 'Germany', 'Cabo Verde', 'Tunisia',\n'Myanmar', 'Congo Republic', 'Iran', 'South Korea', 'North Korea'\\]. The\ninput format is determined automatically, based on ISO two letter, ISO\nthree letter, ISO numeric or regular expression matching. In case of any\nambiguity, the source format can be specified with the parameter 'src'.\n\nIn case of multiple conversion, better performance can be achieved by\ninstantiating a single CountryConverter object for all conversions:\n\n``` python\nimport country_converter as coco\ncc = coco.CountryConverter()\n\nsome_names = ['United Rep. of Tanzania', 'Cape Verde', 'Burma',\n              'Iran (Islamic Republic of)', 'Korea, Republic of',\n              \"Dem. People's Rep. of Korea\"]\n\nstandard_names = cc.convert(names = some_names, to = 'name_short')\nUNmembership = cc.convert(names = some_names, to = 'UNmember')\nprint(standard_names)\nprint(UNmembership)\n```\n\nIn order to more efficiently convert Pandas Series, the `pandas_convert()` method can be used. The\nperformance gain is especially significant for large Series. For a series containing 1 million rows\na 4000x speedup can be achieved, compared to `convert()`.\n\n``` python\nimport country_converter as coco\nimport pandas as pd\ncc = coco.CountryConverter()\n\nsome_countries = pd.Series(['Australia', 'Belgium', 'Brazil', 'Bulgaria', 'Cyprus', 'Czech Republic',\n                  'Guatemala', 'Mexico', 'Honduras', 'Costa Rica', 'Colombia', 'Greece', 'Hungary',\n                  'India', 'Indonesia', 'Ireland', 'Italy', 'Japan', 'Latvia', 'Lithuania',\n                  'Luxembourg', 'Malta', 'Jamaica', 'Ireland', 'Turkey', 'United Kingdom',\n                  'United States'], name='country')\n \niso3_codes = cc.pandas_convert(series=some_countries, to='ISO3')                  \n```\n\nConvert between classification schemes:\n\n``` python\niso3_codes = ['USA', 'VUT', 'TKL', 'AUT', 'XXX' ]\niso2_codes = coco.convert(names=iso3_codes, to='ISO2')\nprint(iso2_codes)\n```\n\nWhich results in \\['US', 'VU', 'TK', 'AT', 'not found'\\]\n\nThe not found indication can be specified (e.g. not_found = 'not\nthere'), if None is passed for 'not_found', the original entry gets\npassed through:\n\n``` python\niso2_codes = coco.convert(names=iso3_codes, to='ISO2', not_found=None)\nprint(iso2_codes)\n```\n\nresults in \\['US', 'VU', 'TK', 'AT', 'XXX'\\]\n\nInternally the data is stored in a Pandas DataFrame, which can be\naccessed directly. For example, this can be used to filter countries for\nmembership organisations (per year). Note: for this, an instance of\nCountryConverter is required.\n\n``` python\nimport country_converter as coco\ncc = coco.CountryConverter()\n\nsome_countries = ['Australia', 'Belgium', 'Brazil', 'Bulgaria', 'Cyprus', 'Czech Republic',\n                  'Denmark', 'Estonia', 'Finland', 'France', 'Germany', 'Greece', 'Hungary',\n                  'India', 'Indonesia', 'Ireland', 'Italy', 'Japan', 'Latvia', 'Lithuania',\n                  'Luxembourg', 'Malta', 'Romania', 'Russia', 'Turkey', 'United Kingdom',\n                  'United States']\n\noecd_since_1995 = cc.data[(cc.data.OECD >= 1995) & cc.data.name_short.isin(some_countries)].name_short\neu_until_1980 = cc.data[(cc.data.EU <= 1980) & cc.data.name_short.isin(some_countries)].name_short\nprint(oecd_since_1995)\nprint(eu_until_1980)\n```\n\nAll classifications can be directly accessed by:\n\n``` python\ncc.EU28\ncc.OECD\n\ncc.EU27as('ISO3')\n```\n\nand the classification schemes available:\n\n``` python\ncc.valid_class\n```\n\nThere is also a methdod for only getting country classifications (thus\nomitting any grouping of countries):\n\n``` python\ncc.valid_country_classifications\n```\n\nIf you rather need a dictionary describing the classification/membership\nuse:\n\n``` python\nimport country_converter as coco\ncc = coco.CountryConverter()\ncc.get_correspondence_dict('EXIO3', 'ISO3')\n```\n\nto also include countries not assigned within a specific classification\nuse:\n\n``` python\ncc.get_correspondence_dict('EU27', 'ISO2', replace_nan='NonEU')\n```\n\nThe regular expressions can also be used to match any list of countries\nto any other. For example:\n\n``` python\nmatch_these = ['norway', 'united_states', 'china', 'taiwan']\nmaster_list = ['USA', 'The Swedish Kingdom', 'Norway is a Kingdom too',\n               'Peoples Republic of China', 'Republic of China' ]\n\nmatching_dict = coco.match(match_these, master_list)\n```\n\nCountry converter by default provides a warning to the python <span\nclass=\"title-ref\">logging</span> logger if no match is found. The\nfollowing example demonstrates how to configure the <span\nclass=\"title-ref\">coco</span> logging behaviour.\n\n``` python\nimport logging\nimport country_converter as coco\nlogging.basicConfig(level=logging.INFO)\ncoco.convert(\"asdf\")\n# WARNING:country_converter.country_converter:asdf not found in regex\n# Out: 'not found'\n\ncoco_logger = coco.logging.getLogger()\ncoco_logger.setLevel(logging.CRITICAL)\ncoco.convert(\"asdf\")\n# Out: 'not found'\n```\n\nSee the IPython Notebook\n([country_converter_examples.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_examples.ipynb))\nfor more information.\n\n#### Command line usage\n\nThe country converter package also provides a command line interface\ncalled coco.\n\nMinimal example:\n\n    coco Cyprus DE Denmark Estonia 4 'United Kingdom' AUT\n\nConverts the given names to ISO3 codes based on matching the input to\nISO2, ISO3, ISOnumeric or regular expression matching. The list of names\nmust be separated by spaces, country names consisting of multiple words\nmust be put in quotes ('').\n\nThe input classification can be specified with '--src' or '-s' (or will\nbe determined automatically), the target classification with '--to' or\n'-t'.\n\nThe default output is a space separated list, this can be changed by\npassing a separator by '--output_sep' or '-o' (e.g -o '\\|').\n\nThus, to convert from ISO3 to UN number codes and receive the output as\ncomma separated list use:\n\n    coco AUT DEU VAT AUS -s ISO3 -t UNcode -o ', '\n\nThe command line tool also allows to specify the output for none found\nentries, including passing them through to the output by passing None:\n\n    coco CAN Peru US Mexico Venezuela UK Arendelle --not_found=None\n\nand to specify an additional data file which will overwrite existing\ncountry matching\n\n    coco Congo --additional_data path/to/datafile.csv\n\nSee\n<https://github.com/IndEcol/country_converter/tree/master/tests/custom_data_example.txt>\nfor an example of an additional datafile.\n\nThe flags --UNmember_only (-u) and --include_obsolete (-i) restrict the\nsearch to UN member states only or extend it to also include currently\nobsolete countries. For example, the [Netherlands\nAntilles](https://en.wikipedia.org/wiki/Netherlands_Antilles) were\ndissolved in 2010.\n\nThus:\n\n    coco \"Netherlands Antilles\"\n\nresults in \"not found\". The search, however, can be extended to recently\ndissolved countries by:\n\n    coco \"Netherlands Antilles\" -i\n\nwhich results in 'ANT'.\n\nIn addition to the countries, the coco command line tool also accepts\nvarious country classifications (EXIO1, EXIO2, EXIO3, WIOD, Eora,\nMESSAGE, OECD, EU27, EU28, UN, obsolete, Cecilia2050, BRIC, APEC, BASIC,\nCIS, G7, G20). One of these can be passed by\n\n    coco G20\n\nwhich lists all countries in that classification.\n\nFor the classifications covering almost all countries (MRIO and IAM\nclassifications)\n\n    coco EXIO3\n\nlists the unique classification names. When passing a --to parameter, a\nsimplified correspondence of the chosen classification is printed:\n\n    coco EXIO3 --to ISO3\n\nFor further information call the help by\n\n    coco -h\n\n#### Use in Matlab\n\nNewer (tested in 2016a) versions of Matlab allow to directly call Python\nfunctions and libraries. This requires a Python version \\>= 3.4\ninstalled in the system path (e.g. through Anaconda).\n\nTo test, try this in Matlab:\n\n``` matlab\npy.print(py.sys.version)\n```\n\nIf this works, you can also use coco after installing it through pip (at\nthe windows commandline - see the installing instruction above):\n\n``` matlab\npip install country_converter --upgrade\n```\n\nAnd in matlab:\n\n``` matlab\ncoco = py.country_converter.CountryConverter()\ncountries = {'The Swedish Kingdom', 'Norway is a Kingdom too', 'Peoples Republic of China', 'Republic of China'};\nISO2_pythontype = coco.convert(countries, pyargs('to', 'ISO2'));\nISO2_cellarray = cellfun(@char,cell(ISO2_pythontype),'UniformOutput',false);\n```\n\nAlternatively, as a long oneliner:\n\n``` matlab\nshort_names = cellfun(@char, cell(py.country_converter.convert({56, 276}, pyargs('src', 'UNcode', 'to', 'name_short'))), 'UniformOutput',false);\n```\n\nAll properties of coco as explained above are also available in Matlab:\n\n``` matlab\ncoco = py.country_converter.CountryConverter();\ncoco.EU27\nEU27ISO3 = coco.EU27as('ISO3');\n```\n\nThese functions return a Pandas DataFrame. The underlying values can be\naccess with .values (e.g.\n\n``` matlab\nEU27ISO3.values\n```\n\nI leave it to professional Matlab users to figure out how to further\nprocess them.\n\nSee also IPython Notebook\n([country_converter_examples.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_examples.ipynb))\nfor more information - all functions available in Python (for example\npassing additional data files, specifying the output in case of missing\ndata) work also in Matlab by passing arguments through the pyargs\nfunction.\n\n### Building concordances for country aggregation\n\nCoco provides a function for building concordance vectors, matrices and\ndictionaries between different classifications. This can be used in\npython as well as in matlab. For further information see\n([country_converter_aggregation_helper.ipynb](http://nbviewer.ipython.org/github/IndEcol/country_converter/blob/master/doc/country_converter_aggregation_helper.ipynb))\n\n## Classification schemes\n\nCurrently the following classification schemes are available (see also\nData sources below for further information):\n\n1.  ISO2 (ISO 3166-1 alpha-2) - including UK/EL for Britain/Greece (but always convert to GB/GR)\n2.  ISO3 (ISO 3166-1 alpha-3)\n3.  ISO - numeric (ISO 3166-1 numeric)\n4.  UN numeric code (M.49 - follows to a large extend ISO-numeric)\n5.  A standard or short name\n6.  The \"official\" name\n7.  Continent: 6 continent classification with Africa, Antarctica, Asia, Europe, America, Oceania\n8.  [Continent_7 classification](https://ourworldindata.org/world-region-map-definitions) - 7 continent classification spliting North/South America\n9.  UN region\n10. [EXIOBASE 1](http://exiobase.eu/) classification (2 and 3 letters)\n11. [EXIOBASE 2](http://exiobase.eu/) classification (2 and 3 letters)\n12. [EXIOBASE 3](https://zenodo.org/doi/10.5281/zenodo.3583070) classification (2 and 3 letters)\n13. [WIOD](http://www.wiod.org/home) classification\n14. [Eora](http://www.worldmrio.com/)\n15. [OECD](http://www.oecd.org/about/membersandpartners/list-oecd-member-countries.htm)\n    membership (per year)\n16. [MESSAGE](http://www.iiasa.ac.at/web/home/research/researchPrograms/Energy/MESSAGE-model-regions.en.html)\n    11-region classification\n17. [IMAGE](https://models.pbl.nl/image/index.php/Welcome_to_IMAGE_3.0_Documentation)\n18. [REMIND](https://www.pik-potsdam.de/en/institute/departments/transformation-pathways/models/remind)\n19. [UN](http://www.un.org/en/members/) membership (per year)\n20. [EU](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements)\n    membership (including EU12, EU15, EU25, EU27, EU27_2007, EU28)\n21. [EEA](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:European_Economic_Area_(EEA))\n    membership\n22. [Schengen](https://en.wikipedia.org/wiki/Schengen_Area) region\n23. [Cecilia](https://cecilia2050.eu/system/files/De%20Koning%20et%20al.%20%282014%29_Scenarios%20for%202050_0.pdf)\n    2050 classification\n24. [APEC](https://en.wikipedia.org/wiki/Asia-Pacific_Economic_Cooperation)\n25. [BRIC](https://en.wikipedia.org/wiki/BRIC)\n26. [BASIC](https://en.wikipedia.org/wiki/BASIC_countries)\n27. [CIS](https://en.wikipedia.org/wiki/Commonwealth_of_Independent_States)\n    (as by 2019, excl. Turkmenistan)\n28. [G7](https://en.wikipedia.org/wiki/Group_of_Seven)\n29. [G20](https://en.wikipedia.org/wiki/G20) (listing all EU member\n    states as individual members)\n30. [FAOcode](http://www.fao.org/faostat/en/#definitions) (numeric)\n31. [GBDcode](http://ghdx.healthdata.org/) (numeric - Global Burden of\n    Disease country codes)\n32. [IEA](https://www.iea.org/countries) (World Energy Balances 2021)\n33. [DACcode](https://www.oecd.org/dac/financing-sustainable-development/development-finance-standards/dacandcrscodelists.htm)\n    (numeric - OECD Development Assistance Committee)\n33. [ccTLD](https://en.wikipedia.org/wiki/Country_code_top-level_domain) - country code top-level domains\n34. [GWcode](https://www.tandfonline.com/doi/abs/10.1080/03050629908434958) - Gledisch & Ward numerical codes as published in https://www.andybeger.com/states/articles/statelists.html\n35. CC41 - common classification for MRIOs (list of countries found in all public MRIOs)\n36. [IOC](https://en.wikipedia.org/wiki/List_of_IOC_country_codes) - International Olympic Committee (IOC) country codes\n\n\nCoco contains official recognised codes as well as non-standard codes\nfor disputed or dissolved countries. To restrict the set to only the\nofficial recognized UN members or include obsolete countries, pass\n\n``` python\nimport country_converter as coco\ncc = coco.CountryConverter()\ncc_UN = coco.CountryConverter(only_UNmember=True)\ncc_all = coco.CountryConverter(include_obsolete=True)\n\ncc.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')\ncc_UN.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')\ncc_all.convert(['PSE', 'XKX', 'EAZ', 'FRA'], to='name_short')\n```\n\ncc results in \\['Palestine', 'Kosovo', 'not found', 'France'\\], whereas\ncc_UN converts to \\['not found', 'not found', 'not found', 'France'\\]\nand cc_all converts to \\['Palestine', 'Kosovo', 'Zanzibar', 'France'\\]\nNote that the underlying dataframe is available at the attribute .data\n(e.g. cc_all.data).\n\n## Data sources and further reading\n\nMost of the underlying data can be found in Wikipedia, the page describing [ISO\n3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) is a good starting point. The\npage on the [ISO2 codes](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2)\nincludes a section \"Imperfect Implementations\" explaining the GB/UK and EL/GR\nissue.\nUN regions/codes are given on the United Nation\nStatistical Division\n([unstats](http://unstats.un.org/unsd/methods/m49/m49regin.htm))\nwebpage. The differences between the ISO numeric and UN (M.49) codes are\n[also explained at wikipedia](https://en.wikipedia.org/wiki/UN_M.49).\n[EXIOBASE](http://exiobase.eu/), [WIOD](http://www.wiod.org/home) and\n[Eora](http://www.worldmrio.com/) classification were extracted from the\nrespective databases. For [Eora](http://www.worldmrio.com/), the names\nare based on the 'Country names' csv file provided on the webpage, but\nupdated for different names used in the Eora26 database. The MESSAGE\nclassification follows the 11-region aggregation given in the\n[MESSAGE](http://www.iiasa.ac.at/web/home/research/researchPrograms/Energy/MESSAGE-model-regions.en.html)\nmodel regions description. The\n[IMAGE](https://models.pbl.nl/image/index.php/Welcome_to_IMAGE_3.0_Documentation)\nclassification is based on the \"[region classification\nmap](https://models.pbl.nl/image/index.php/Region_classification_map)\",\nfor\n[REMIND](https://www.pik-potsdam.de/en/institute/departments/transformation-pathways/models/remind)\nwe received a country mapping from the model developers.\n\nThe membership of\n[OECD](http://www.oecd.org/about/membersandpartners/list-oecd-member-countries.htm)\nand [UN](http://www.un.org/en/members/) can be found at the membership\norganisations' webpages, information about obsolete country codes on the\n[Statoids](http://www.statoids.com/w3166his.html) webpage.\n\nThe situation for the\n[EU](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements)\ngot complicated due to the Brexit process. For the naming, coco follows\nthe [Eurostat\nglossary](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:EU_enlargements),\nthus EU27 refers to the EU without UK, whereas EU27_2007 refers to the\nEU without Croatia (the status after the 2007 enlargement). The shortcut\nEU always links to the most recent classification. The\n[EEA](https://ec.europa.eu/eurostat/statistics-explained/index.php/Glossary:European_Economic_Area_(EEA))\nagreements for the UK ended by 2021-01-01 (which also affects Guernsey, Isle of Man, Jersey and Gibraltar). \nSwitzerland is not part of the EEA but member of the single market.\n\nThe Global Burden of Disease country codes were extracted form the [GBD\ncode book available\nhere.](https://ghdx.healthdata.org/sites/default/files/ihme_query_tool/IHME_GBD_2019_CODEBOOK.zip)\n\n## Communication, issues, bugs and enhancements\n\nPlease use the issue tracker for documenting bugs, proposing\nenhancements and all other communication related to coco.\n\nYou can follow me on [mastodon - @kst@qoto.org](https://qoto.org/@kst) and [twitter](https://twitter.com/kst_stadler) to get\nthe latest news about all my open-source and research projects (and\noccasionally some random retweets/toots).\n\n## Contributing\n\nWant to contribute? Great! Please check\n[CONTRIBUTING.md](CONTRIBUTING.md) if you want to help to improve coco\nand for some pointer for how to add classifications.\n\n## Related software\n\nThe package [pycountry](https://pypi.python.org/pypi/pycountry) provides\naccess to the official ISO databases for historic countries, country\nsubdivisions, languages and currencies. In case you need to convert\nnon-English country names,\n[countrynames](https://github.com/occrp/countrynames) includes an\nextensive database of country names in different languages and functions\nto convert them to the different ISO 3166 standards.\n[Python-iso3166](https://github.com/deactivated/python-iso3166) focuses\non conversion between the two-letter, three-letter and three-digit codes\ndefined in the ISO 3166 standard.\n\nIf you are using R, you should have a look at\n[countrycode](https://github.com/vincentarelbundock/countrycode).\n\n## Citing the country converter\n\nVersion 0.5 of the country converter was published in the [Journal of\nOpen Source Software](http://joss.theoj.org/). To cite the country\nconverter in publication please use:\n\nStadler, K. (2017). The country converter coco - a Python package for\nconverting country names between different classification schemes. The\nJournal of Open Source Software. doi:\n[10.21105/joss.00332](http://dx.doi.org/10.21105/joss.00332)\n\nFor the full bibtex key see [CITATION](CITATION)\n\n## Acknowledgements\n\nThis package was inspired by (and the regular expression are mostly\nbased on) the R-package\n[countrycode](https://github.com/vincentarelbundock/countrycode) by\n[Vincent Arel-Bundock](http://arelbundock.com/) and his (defunct) port\nto Python (pycountrycode). Many thanks to [Robert\nGieseke](https://github.com/rgieseke) for the review of the source code\nand paper for the publication in the [Journal of Open Source\nSoftware](http://joss.theoj.org/).\n",
    "bugtrack_url": null,
    "license": "GNU General Public License v3 (GPLv3)",
    "summary": "The country converter (coco) - a Python package for converting country names between different classifications schemes",
    "version": "1.2",
    "project_urls": {
        "Repository": "https://github.com/IndEcol/country_converter"
    },
    "split_keywords": [
        "country",
        "iso 3166"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "722a0701fa1349dd2b26f368b758d38efa9a64138fe726ebeb188bf137d73988",
                "md5": "a0b032861307e9fa255e27567cd547d4",
                "sha256": "5a5e54f9542cc8e109d53a39fa9e9179e6a97826e72594dd16e948611cb278fa"
            },
            "downloads": -1,
            "filename": "country_converter-1.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "a0b032861307e9fa255e27567cd547d4",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 45964,
            "upload_time": "2023-12-12T20:12:28",
            "upload_time_iso_8601": "2023-12-12T20:12:28.076658Z",
            "url": "https://files.pythonhosted.org/packages/72/2a/0701fa1349dd2b26f368b758d38efa9a64138fe726ebeb188bf137d73988/country_converter-1.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ff867f33a4394b882ba4a2c6eb08cc71a4c2dc616ca3bdd622db0cbdfea13fe8",
                "md5": "fd306d7b1a784015f78e9e43f3bc6155",
                "sha256": "74e87db54b91eda56c5eecc9e36e1b5ca79ca2bca58012ecc4f55ef8a13a6631"
            },
            "downloads": -1,
            "filename": "country_converter-1.2.tar.gz",
            "has_sig": false,
            "md5_digest": "fd306d7b1a784015f78e9e43f3bc6155",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 59781,
            "upload_time": "2023-12-12T20:12:30",
            "upload_time_iso_8601": "2023-12-12T20:12:30.089156Z",
            "url": "https://files.pythonhosted.org/packages/ff/86/7f33a4394b882ba4a2c6eb08cc71a4c2dc616ca3bdd622db0cbdfea13fe8/country_converter-1.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-12-12 20:12:30",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "IndEcol",
    "github_project": "country_converter",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "lcname": "country-converter"
}
        
Elapsed time: 0.26850s