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.

Files for mobile-codes, version 0.7
Filename, size File type Python version Upload date Hashes
Filename, size mobile-codes-0.7.tar.gz (82.0 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page