1
|
|
|
<?php |
2
|
|
|
/** |
3
|
|
|
* @link https://en.wikipedia.org/wiki/Category:Postal_system Postal Systems by Country |
4
|
|
|
* @link http://dmoztools.net/Reference/Directories/Address_and_Phone_Numbers/Postal_Codes/ DMOZ Post/Zip Code Info+DB |
5
|
|
|
* @link https://en.wikipedia.org/wiki/List_of_postal_codes List of Postal Codes |
6
|
|
|
* @param $what |
7
|
|
|
* @param $codes |
8
|
|
|
* @return array |
9
|
|
|
* @internal param mixed $ |
10
|
|
|
*/ |
11
|
|
|
function get_codes_from($what, $codes, $iso) |
12
|
|
|
{ |
13
|
|
|
$what = explode(',', $what); |
14
|
|
|
foreach ($what as $eachArea) { |
15
|
|
|
if (trim($eachArea) != '' && trim($eachArea) != '- no codes -') { |
16
|
|
|
$codes[] = "'".str_replace(['N', 'A', 'CC'], ['#', '@', $iso], trim($eachArea))."'"; |
17
|
|
|
} |
18
|
|
|
} |
19
|
|
|
return $codes; |
20
|
|
|
} |
21
|
|
|
|
22
|
|
|
require __DIR__.'/../../../../include/functions.inc.php'; |
23
|
|
|
function_requirements('getcurlpage'); |
|
|
|
|
24
|
|
|
$page = getcurlpage('https://en.wikipedia.org/wiki/Special:Export/List_of_postal_codes'); |
|
|
|
|
25
|
|
|
$page = str_replace(["\n\n", '<', '>', '&', '<br />'], ["\n", '<', '>', '&', ''], $page); |
26
|
|
|
$lines = explode("\n", $page); |
27
|
|
|
$found = []; |
28
|
|
|
$out = []; |
29
|
|
|
for ($x = 0, $xMax = sizeof($lines); $x < $xMax; $x++) { |
30
|
|
|
$line = $lines[$x]; |
31
|
|
|
if ((trim($line) == '|-' || trim($line) == '|-.') && mb_substr($lines[$x + 1], 0, 1) != '!') { |
32
|
|
|
$x++; |
33
|
|
|
$country = preg_replace('/\| *\[\[Postal codes in [^\|]*\|(.*)\]\]/msU', '\1', $lines[$x]); |
34
|
|
|
$x++; |
35
|
|
|
$years = trim($lines[$x]); |
36
|
|
|
$x++; |
37
|
|
|
$iso = preg_replace('/\| *\[\[ISO 3166-[0-9]*:[A-Z]*\|(.*)\]\]/msU', '\1', $lines[$x]); |
38
|
|
|
$area = ''; |
39
|
|
|
$street = ''; |
40
|
|
|
$notes = array_key_exists($iso, $out) ? $out[$iso]['notes'] : ''; |
41
|
|
|
if (trim($lines[$x + 1]) != '|-') { |
42
|
|
|
$x++; |
43
|
|
|
$area = trim(mb_substr($lines[$x], 1)); |
44
|
|
|
if (trim($lines[$x + 1]) != '|-') { |
45
|
|
|
$x++; |
46
|
|
|
$street = trim(mb_substr($lines[$x], 1)); |
47
|
|
|
if (trim($lines[$x + 1]) != '|-') { |
48
|
|
|
$x++; |
49
|
|
|
if (trim(mb_substr($lines[$x], 1)) != '') { |
50
|
|
|
$notes .= ($years != '' ? $years.' ' : '') . trim(mb_substr($lines[$x], 1)); |
51
|
|
|
} |
52
|
|
|
} |
53
|
|
|
} |
54
|
|
|
} |
55
|
|
|
$codes = array_key_exists($iso, $out) ? $out[$iso]['codes'] : []; |
56
|
|
|
$codes = get_codes_from($area, $codes, $iso); |
57
|
|
|
$codes = get_codes_from($street, $codes, $iso); |
58
|
|
|
$found[] = $iso; |
59
|
|
|
$out[$iso] = [ |
60
|
|
|
'codes' => $codes, |
61
|
|
|
'country' => $country, |
62
|
|
|
'notes' => $notes, |
63
|
|
|
]; |
64
|
|
|
} |
65
|
|
|
} |
66
|
|
|
$db = $GLOBALS['tf']->db; |
67
|
|
|
$db->query('select * from country_t order by iso2;'); |
68
|
|
|
while ($db->next_record(MYSQL_ASSOC)) { |
|
|
|
|
69
|
|
|
if (!in_array($db->Record['iso2'], $found)) { |
70
|
|
|
$out[$db->Record['iso2']] = [ |
71
|
|
|
'codes' => [], |
72
|
|
|
'country' => $db->Record['short_name'], |
73
|
|
|
'notes' => '', |
74
|
|
|
]; |
75
|
|
|
} |
76
|
|
|
} |
77
|
|
|
$keys = array_keys($out); |
78
|
|
|
sort($keys); |
79
|
|
|
foreach ($keys as $iso) { |
80
|
|
|
$codes = $out[$iso]['codes']; |
81
|
|
|
$country = $out[$iso]['country']; |
82
|
|
|
$notes = $out[$iso]['notes']; |
83
|
|
|
echo " '{$iso}' => [".implode(', ', $codes).'],'." // $country".(trim($notes) != '' ? ', Notes: '.$notes : '').PHP_EOL; |
84
|
|
|
} |
85
|
|
|
|