Конвертировать коды стран - PullRequest
       16

Конвертировать коды стран

14 голосов
/ 11 августа 2010

Есть несколько методов для кодов стран.

У меня есть список кодов с 3 символами, как на этой странице:

http://www.fina.org/H2O/index.php?option=com_content&view=category&id=93:asia&Itemid=638&layout=default

Есть ли простой способ преобразовать их в 2-символьные? Как "PT" из "POR" для Португалии.

Стандарт для 2-символьных - http://en.wikipedia.org/wiki/ISO_3166-1_alpha-2

Спасибо.

Ответы [ 12 ]

22 голосов
/ 11 сентября 2014

Есть несколько полезных файлов данных, которые вы можете получить из http://country.io/data, которые помогут вам:

Если вы просто хотите перейти от 3 буквенных кодов к 2 буквенным кодам, вы можете просто перевернуть первую карту и использовать ее. Вы можете создать карту, которая идет непосредственно из трехбуквенных кодов к названиям стран, комбинируя файлы. Вот простой пример PHP:

$codes = json_decode(file_get_contents('http://country.io/iso3.json'), true);
$names = json_decode(file_get_contents('http://country.io/names.json'), true);
$iso3_to_name = array();
foreach($codes as $iso2 => $iso3) {
    $iso3_to_name[$iso3] = $names[$iso2];
}

echo $names("PL"); // => "Poland"
echo $iso3_to_map("POL"); // => "Poland"
7 голосов
/ 29 августа 2017

Я вижу, что вопрос был задан семь лет назад.Сегодня у меня была похожая проблема, и я нашел одно хорошее решение.Надеюсь, что этот ответ будет полезен для других, у кого будет такая же проблема в будущем.

Существует отдельная библиотека, которую можно использовать https://github.com/thephpleague/iso3166

Тогда решение будет простым. $ alpha3 - это трехзначное представление страны.И alpha2 является представлением страны с двумя символами.

  1. $ composer require league/iso3166
  2. $data = (new League\ISO3166\ISO3166)->alpha3($alpha3);
  3. Данные выглядят следующим образом:

    [
      'name' => 'Netherlands',
      'alpha2' => 'NL',
      'alpha3' => 'NLD',
      'numeric' => '528',
      'currency' => [
        'EUR',
        ]
    ]
    
  4. $countryCodeInTwoChar = $data['alpha2']
3 голосов
/ 11 августа 2010

Без фактического поиска не существует простого способа: AFG (Афганистан) становится AF, а AND (Андорра) становится AD, а BLR (Беларусь) становится BY ... поэтому вы не можете выполнять какие-либо простые манипуляции с персонажами конвертировать.

Я бы предложил использовать таблицу кодов стран или добавить дополнительный столбец к любой существующей таблице, чтобы вы содержали оба кода.

2 голосов
/ 05 ноября 2016

Большинство других ответов выше не являются прямыми.Позвольте мне попробовать

Я пробовал ниже код для преобразования 3-х символов в 2-х значный код страны с использованием API :

<?php
    $list=["BWA","SLV","TZA","BRB","IND","BES","ANT"];
    $iso3=file_get_contents('http://country.io/iso3.json');//load the country codes
    $iso3=json_decode($iso3,true);//convert json to associative array
    foreach($list as $k)
    {
        if($k=="ANT")//not defined in code list
            echo "AN";
        else
            echo array_search($k,$iso3); 
        echo "<br/>";
    }
?>

предоставленные коды стран представлены в виде 2-изо (ключ): 3-изо (значение).Поэтому вместо поиска ключа я искал по значению и возвращал первый соответствующий ключ в случае успеха.

Вывод

BW

SV

TZ

BB

IN

BQ

AN

Минусы -

ANT код страны не определен в списке кодов.

Ссылка - array_search

2 голосов
/ 27 июля 2016

Для тех, кто занимается этим, я сделал отображение JSON от alpha3 до alpha2. Скачать здесь: https://api.myjson.com/bins/1y2hn

Таким образом, вы просто назначаете этот JSON объекту (например, countryCodes). Теперь преобразование просто: countryCodes["US"] //"USA"

2 голосов
/ 11 августа 2010

В gis.stackexchange есть похожий вопрос.
https://gis.stackexchange.com/questions/603/is-a-country-state-city-database-available
Я думаю, что вы получите больше информации, разместив эти вопросы в ГИС. http://gis.stackexchange.com

1 голос
/ 24 марта 2017

Массив на основе Json с кодами ISO 3, но не отсортированный

Вставить ссылку на бин

и PHP Array Вставить BIN PHP Array

1 голос
/ 11 августа 2010

Хотя это может быть длительный и болезненный метод, он вполне может стоить того, чтобы написать функцию, которую вы можете хранить вечно, возможно, это может указать вам правильное направление:

<?php
function myCodes($in, $type){
$out = "";
$long = array('portugal', 'united kingdom');
$short = array('pt', 'uk');
$in = strtolower(trim($in));
switch($type){
case 'long':$out = str_replace($short, $long, $in);break;
case 'short':$out = str_replace($long, $short, $in);break;
}
echo $out;
}

echo myCodes('United Kingdom', 'short'); //this will echo 'uk'
echo myCodes('UK', 'long'); //this will echo 'united kingdom'

?>

Это, конечно, будет иметь несколько недостатков, таких как уверенность в том, что массивы для длинных и коротких позиций совпадают, и вам нужно будет также поддерживать функцию.

0 голосов
/ 04 ноября 2018

Основываясь на другой информации здесь, вот полная функция, готовая к работе:

function convertCountryAlphas3To2($code='') {
 $countries = json_decode('{"AFG":"AF","ALA":"AX","ALB":"AL","DZA":"DZ","ASM":"AS","AND":"AD","AGO":"AO","AIA":"AI","ATA":"AQ","ATG":"AG","ARG":"AR","ARM":"AM","ABW":"AW","AUS":"AU","AUT":"AT","AZE":"AZ","BHS":"BS","BHR":"BH","BGD":"BD","BRB":"BB","BLR":"BY","BEL":"BE","BLZ":"BZ","BEN":"BJ","BMU":"BM","BTN":"BT","BOL":"BO","BIH":"BA","BWA":"BW","BVT":"BV","BRA":"BR","VGB":"VG","IOT":"IO","BRN":"BN","BGR":"BG","BFA":"BF","BDI":"BI","KHM":"KH","CMR":"CM","CAN":"CA","CPV":"CV","CYM":"KY","CAF":"CF","TCD":"TD","CHL":"CL","CHN":"CN","HKG":"HK","MAC":"MO","CXR":"CX","CCK":"CC","COL":"CO","COM":"KM","COG":"CG","COD":"CD","COK":"CK","CRI":"CR","CIV":"CI","HRV":"HR","CUB":"CU","CYP":"CY","CZE":"CZ","DNK":"DK","DKK":"DK","DJI":"DJ","DMA":"DM","DOM":"DO","ECU":"EC","Sal":"El","GNQ":"GQ","ERI":"ER","EST":"EE","ETH":"ET","FLK":"FK","FRO":"FO","FJI":"FJ","FIN":"FI","FRA":"FR","GUF":"GF","PYF":"PF","ATF":"TF","GAB":"GA","GMB":"GM","GEO":"GE","DEU":"DE","GHA":"GH","GIB":"GI","GRC":"GR","GRL":"GL","GRD":"GD","GLP":"GP","GUM":"GU","GTM":"GT","GGY":"GG","GIN":"GN","GNB":"GW","GUY":"GY","HTI":"HT","HMD":"HM","VAT":"VA","HND":"HN","HUN":"HU","ISL":"IS","IND":"IN","IDN":"ID","IRN":"IR","IRQ":"IQ","IRL":"IE","IMN":"IM","ISR":"IL","ITA":"IT","JAM":"JM","JPN":"JP","JEY":"JE","JOR":"JO","KAZ":"KZ","KEN":"KE","KIR":"KI","PRK":"KP","KOR":"KR","KWT":"KW","KGZ":"KG","LAO":"LA","LVA":"LV","LBN":"LB","LSO":"LS","LBR":"LR","LBY":"LY","LIE":"LI","LTU":"LT","LUX":"LU","MKD":"MK","MDG":"MG","MWI":"MW","MYS":"MY","MDV":"MV","MLI":"ML","MLT":"MT","MHL":"MH","MTQ":"MQ","MRT":"MR","MUS":"MU","MYT":"YT","MEX":"MX","FSM":"FM","MDA":"MD","MCO":"MC","MNG":"MN","MNE":"ME","MSR":"MS","MAR":"MA","MOZ":"MZ","MMR":"MM","NAM":"NA","NRU":"NR","NPL":"NP","NLD":"NL","ANT":"AN","NCL":"NC","NZL":"NZ","NIC":"NI","NER":"NE","NGA":"NG","NIU":"NU","NFK":"NF","MNP":"MP","NOR":"NO","OMN":"OM","PAK":"PK","PLW":"PW","PSE":"PS","PAN":"PA","PNG":"PG","PRY":"PY","PER":"PE","PHL":"PH","PCN":"PN","POL":"PL","PRT":"PT","PRI":"PR","QAT":"QA","REU":"RE","ROU":"RO","RUS":"RU","RWA":"RW","BLM":"BL","SHN":"SH","KNA":"KN","LCA":"LC","MAF":"MF","SPM":"PM","VCT":"VC","WSM":"WS","SMR":"SM","STP":"ST","SAU":"SA","SEN":"SN","SRB":"RS","SYC":"SC","SLE":"SL","SGP":"SG","SVK":"SK","SVN":"SI","SLB":"SB","SOM":"SO","ZAF":"ZA","SGS":"GS","SSD":"SS","ESP":"ES","LKA":"LK","SDN":"SD","SUR":"SR","SJM":"SJ","SWZ":"SZ","SWE":"SE","CHE":"CH","SYR":"SY","TWN":"TW","TJK":"TJ","TZA":"TZ","THA":"TH","TLS":"TL","TGO":"TG","TKL":"TK","TON":"TO","TTO":"TT","TUN":"TN","TUR":"TR","TKM":"TM","TCA":"TC","TUV":"TV","UGA":"UG","UKR":"UA","ARE":"AE","GBR":"GB","USA":"US","UMI":"UM","URY":"UY","UZB":"UZ","VUT":"VU","VEN":"VE","VNM":"VN","VIR":"VI","WLF":"WF","ESH":"EH","YEM":"YE","ZMB":"ZM","ZWE":"ZW","GBP":"GB","RUB":"RU","NOK":"NO"}',true);
 $out = $countries[$code];
 return $out;
}
0 голосов
/ 21 июля 2011

В ruby ​​вы можете сделать это так: (get countryInfo.txt из http://download.geonames.org/export/dump/)

require 'csv'
countries_iso3_map = {}
CSV.foreach('countryInfo.txt',:col_sep=>'   ',:row_sep =>:auto) do |row|
   next if row[0][0] == '#' #ignore comments section
   countries_iso3_map[row[0][0,2]]= row[1][0,3]
end
p countries_iso3_map['PT']
...