Skip to main content

Library of ISO 3166, MCC and MNC codes

Project description

Contains the country codes from ISO 3166-1 based on the code based on:

https://github.com/deactivated/python-iso3166/

But also has the MCC and MNC codes based on the Wikipedia page:

http://en.wikipedia.org/wiki/List_of_mobile_country_codes

As well as the latest released listing from ITU:

http://www.itu.int/dms_pub/itu-t/opb/sp/T-SP-E.212B-2014-PDF-E.pdf

Note that MCC codes for a country can be:

  • None (no MCC code)

  • a string (where a country has one code)

  • a tuple of strings (where a country has more than one code)

Installation

$ pip install mobile-codes

Usage

>>> import mobile_codes

Lookup by Mobile Country Code (MCC):

>>> mobile_codes.mcc("648")
[Country(name=u'Zimbabwe', alpha2='ZW', alpha3='ZWE', numeric='716', mcc='648')]
>>> mobile_codes.mcc("311")
[Country(name=u'Guam', alpha2='GU', alpha3='GUM', numeric='316', mcc=('310', '311')),
 Country(name=u'United States', alpha2='US', alpha3='USA', numeric='840', mcc=('310', '311', '313', '316'))]
>>> mobile_codes.mcc("313")
[Country(name=u'United States', alpha2='US', alpha3='USA', numeric='840', mcc=('310', '311', '313', '316'))]

Lookup by name, alpha2, alpha3 (all case insensitive):

>>> mobile_codes.alpha3("CAN")
Country(name=u'Canada', alpha2='CA', alpha3='CAN', numeric='124', mcc='302')
>>> mobile_codes.alpha2("CA")
Country(name=u'Canada', alpha2='CA', alpha3='CAN', numeric='124', mcc='302')
>>> mobile_codes.name('canada')
Country(name=u'Canada', alpha2='CA', alpha3='CAN', numeric='124', mcc='302')

Lookup operators by mcc (returns a list of all operators):

>>> mobile_codes.operators('302')
[Operator(mcc='302', mnc='220', brand='Telus', operator=u'Telus'),
 Operator(mcc='302', mnc='221', brand='Telus', operator=u'Telus'),...

Lookup operator by mcc and Mobile Network Code (MNC):

>>> mobile_codes.mcc_mnc('722', '070')
Operator(mcc='722', mnc='070', brand='Movistar', operator=u'Movistar')

All lookups raise a KeyError if the requested value is not found.

Development

If you want to do development on the library, follow these steps:

  • Create a virtualenv

  • bin/pip install -r requirements/tests.txt

  • bin/nosetests -s mobile_codes

Contributors

  • Hanno Schlichting (hannosch)

  • Jared Kerim (jaredkerim)

Changes

0.6 - 2014-10-14

  • Move network and country constants into JSON files

  • Incorporate ITU data for operators

0.5 - unreleased

0.4 - 2014-06-13

  • Declare compatibility with Python 3.4.

  • Fix a number of country to mcc mappings.

  • Issue #9: Fix typo in mcc for Yemen.

  • Issue #10: Allow 310 as a mcc value for Puerto Rico.

0.3 - 2014-05-14

  • Changed mcc API to always return a list, possibly empty, possibly containing multiple countries.

0.2.2 - 2014-04-22

  • Some tests, docs changes and updates to the records, thanks hannosch.

0.2 - 2013-10-26

  • Added in MNC codes and a script to scrape them.

0.1 - 2013-10-22

  • Added in MCC codes and a lookup.

  • Made completely lazy, no records generated or indexed until first asked for.

Project details


Download files

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

Source Distribution

mobile-codes-0.7.tar.gz (82.0 kB view details)

Uploaded Source

File details

Details for the file mobile-codes-0.7.tar.gz.

File metadata

  • Download URL: mobile-codes-0.7.tar.gz
  • Upload date:
  • Size: 82.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for mobile-codes-0.7.tar.gz
Algorithm Hash digest
SHA256 24f86a85cc98afae2e991307b15414c6870db83db35d9878ea49c6c945717a71
MD5 396a45e87ea49a1e6bf5fef781096115
BLAKE2b-256 ad6633224ff6f5d4831a8721b273b5e95c10ab7bdfe0591e2706eb709c9cc192

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page