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.