Skip to content

Forward and Reverse lookups for full country data sets including country info, phone formats, postal formats, currency, languages and states

Notifications You must be signed in to change notification settings

rolinger/iso-country-complete-data

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 

Repository files navigation

A painstakingly collected data set for country info validation. I got quite tired of independent lists that needed reformatting and that did not have all the necessary info per data set. This is the most comprehensive object json I am aware of. I am going to be writing PHP/JS code for loading and quick data extraction but essentially all you need to do is download the JSON file (CountryData_minify.json) and load it in your scripts and your ready to go.

This data set merges 8 different independent datasets to create a single master country json object that can be used for HTML/Code validation when dealing with country specific information.

    // Two files:
    CountryData_minify.json (233k)
    CountryData_pretty.json (531k)

I now use this object to auto-build Country <select> menus which then preformat and provide validation for all other input/select fields related to that country (IE: state lists, postal/zip code, phone numbers (country code and local number formats))

This object can be used to cross reference any country specific information for:

    // Object Data Includes:
    Alpha2 code
    Alpha3 code
    short name    // (ie: United States)
    long name     // (ie: United States of America)
    isoNumber code
    ioc code      // (olympic committee)
    currency  // see "NOTE 1"
        currency code []
        currency name [] 
        currency symbol [] 
    Languages
    Phone:
        country code    // (ie: +1 (US))
        mobile_begin_with prefix codes
        Phone format lengths    // (ie: XXXYYYZZZZ (10))
    Postal:  // see "NOTE 2" 
        Postal code formats
        Permitted non-postal characters
        Included postal validation regex
        Postal lengths    // see "NOTE 3"
        character sets    // (keyboard/input types: number or text (varchar))
    Country States & State Codes    // (ie: "Alaska" : "AK" )

Sample JS calls:

  //javascript:
  var obj = { dataset } ;
  console.log(obj.country["BEL"]) ;

The above format uses lookup by the 3 character country code (IE: USA) and returns all info about that country. But you can also do quick reverse lookups to get the the 3 character code if you only have country name or country 2 digit code:

//Javascript
var obj = { dataset } ;

// extract country info with only 2 digit code
var alpha3 = obj.country[obj.alpha2_to_alpha3["BE"]] ;  
console.log(obj.country[alpha3] ;

// extract country info with only country name
var alpha3 = obj.country[obj.name_to_alpha3["Belgium"]] ;  
console.log(obj.country[alpha3] ;

Please help keep this data accurate or make contributions to it to expand the datasets. Things that could be added are known zip/postal codes PER country STATE as well as local phone prefix numbers.

NOTE 1: Currencies: Some countries have multiple codes but only one name and symbol (ie: Colombia). Others have multiple codes/multiple names but only one symbol and yet others have multiple codes, names and symbols (ie: Namibia)

NOTE 2: Postal Codes: Not all countries have postal info avaialble. To create consistent data, I analyzed those countries and came up with a default solution Description="No Data", charSet="varchar", postalLength=["7"], ValidationRegex="[a-zA-Z0-9]" for uniformity. You may find my chosen defaults do not suit you. Test for obj.country[code].postal.Description == 'No Data' to create your own defaults...if any.

NOTE 3: Postal Code Lengths: Length variations account for spaces and dashes. US ["5", "10"]. "10" = "12345-1234" or "12345 1234"

Sample Break Out of country-data object:

//console.log(obj.country["BEL"]) ;
{
    "country_formats": {
        "name_to_alpha3": {
            "United States": "USA",
            "Aruba": "ABW",
            "Afghanistan": "AFG",
            "Belgium" : "BEL",
        ...
        },
        "alpha2_to_alpha3": {
            "US": "USA",
            "AW": "ABW",
            "AF": "AFG",
            "BE": "BEL",
         ...
         }
    },
    "BEL": {
        "currency": {
            "currencyCode": [
                "EUR"
            ],
            "currencyName": [
                "Euro Member Countries"
            ],
            "currencySymbol": [
                "&#8364;"
            ]
        },
        "info": {
            "shortName": "Belgium",
            "longName": "Belgium",
            "alpha2": "BE",
            "alpha3": "BEL",
            "isoNumericCode": "56",
            "ioc": "BEL",
            "capitalCity": "Bruxelles [Brussel]",
            "tld": ".be"
        },
        "languages": [
            "deu",
            "fra",
            "nld"
        ],
        "phone": {
            "countryCode": "32",
            "mobile_begin_with": [
                "4"
            ],
            "phone_number_lengths": [
                "9"
            ]
        },
        "postal": {
            "Description": "4-Digits - NNNN",
            "RedundantCharacters": " -",
            "ValidationRegex": "^[0-9]{4}$",
            "charSet": "number",
            "postalLengths": [
                "4"
            ],
            "postalFormats": [
                "NNNN"
            ]
        },
        "states": {
            "Bruxelles-Capitale": "BRU",
            "Rgion Flamande": "VLG",
            "Rgion Walloni": "WAL"
        }
    },