Most active countries

From Geohashing
Revision as of 15:28, 24 August 2021 by Fippe (talk | contribs) (more fun statistics)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

The following table shows countries by their number of reached and total expeditions as of 2021-08-24 15:27:26 UTC.

Methodology and Limitations

For the purpose of this list, a country is defined as anything that has a ISO 3166-1 code.

This page is generated by looking where location templates are transcluded, and at the expeditions category and the coordinates reached category. This page is only as good as those categories.

Check out the program's source code.

Expeditions

# Country Σ 08 09 10 11 12 13 14 15 16 17 18 19 20 21
1 United States of America 5102 622 763 570 371 604 570 345 285 232 155 142 113 196 98
2 Germany 4021 186 509 281 330 307 284 407 363 242 180 218 255 253 204
3 United Kingdom 1346 48 122 102 112 160 93 51 327 186 46 40 28 29 2
4 Australia 657 98 101 54 40 98 79 28 30 26 24 15 16 26 22
5 Finland 562 20 23 52 34 35 91 92 62 42 11 11 26 44 19
6 Canada 502 90 119 105 53 31 29 20 10 4 10 12 5 9 5
7 Sweden 412 26 49 60 77 117 25 14 7 5 4 1 8 13 6
8 Netherlands 366 42 16 9 10 51 21 42 44 34 27 17 19 22 12
9 Switzerland 229 6 15 14 32 42 54 14 12 10 3 2 1 18 6
10 France 164 8 18 7 11 15 14 14 3 6 10 2 7 24 25
11 New Zealand 148 18 7 27 16 12 5 15 16 8 7 10 3 3 1
12 Poland 143 3 4 18 6 13 31 12 22 4 8 7 4 8 3
13 Austria 124 3 4 5 3 2 15 47 24 8 5 2 1 2 3
14 Russia 91 0 0 1 2 21 40 6 2 4 3 0 1 4 7
15 Norway 87 20 2 27 10 16 0 4 3 0 0 0 1 2 2
16 Spain 76 2 5 4 2 8 10 4 4 2 0 5 1 1 28
17 Israel 63 1 9 0 2 6 4 1 0 0 5 22 9 1 3
18 Czechia 53 5 7 6 5 8 4 4 13 0 0 1 0 0 0
19 Italy 51 1 4 8 3 7 12 6 7 1 0 1 0 0 1
20 Denmark 40 7 5 3 3 4 3 3 5 1 0 0 2 2 2
21 Belgium 40 6 5 4 3 9 3 2 2 1 2 2 0 1 0
22 Singapore 37 7 2 0 7 4 5 2 0 2 5 1 0 1 1
23 Argentina 29 0 0 0 0 2 2 3 17 3 1 1 0 0 0
24 Bulgaria 26 0 0 4 8 5 3 6 0 0 0 0 0 0 0
25 Hungary 21 7 1 0 0 0 2 2 5 3 0 0 1 0 0
26 Japan 16 0 6 4 0 5 0 0 1 0 0 0 0 0 0
27 Indonesia 15 0 3 0 1 1 1 2 1 4 1 0 1 0 0
28 India 11 0 0 8 0 1 2 0 0 0 0 0 0 0 0
29 Brazil 11 3 0 0 1 1 0 0 1 1 1 2 0 1 0
30 Ireland 10 0 4 1 2 2 1 0 0 0 0 0 0 0 0
31 Slovenia 9 2 1 1 1 2 0 1 0 1 0 0 0 0 0
32 Slovakia 8 1 0 2 0 0 0 0 4 1 0 0 0 0 0
33 Mexico 8 1 5 1 0 0 0 0 0 0 0 0 0 0 1
34 China 8 0 0 5 1 1 0 0 0 0 0 0 0 0 1
35 international waters 7 2 0 1 0 1 1 0 0 0 0 0 1 1 0
36 Greece 7 0 0 0 0 2 0 2 1 1 0 0 0 1 0
37 South Africa 6 0 2 0 1 1 0 0 0 0 0 2 0 0 0
38 Croatia 6 0 0 0 0 1 0 2 3 0 0 0 0 0 0
39 Nepal 5 0 0 3 2 0 0 0 0 0 0 0 0 0 0
40 Ukraine 4 1 0 0 0 0 0 0 0 0 0 0 0 1 2
41 Turkey 4 0 2 1 0 0 0 0 0 0 0 1 0 0 0
42 Portugal 4 0 1 0 1 0 1 0 0 0 1 0 0 0 0
43 Malaysia 4 0 0 1 0 2 0 0 0 0 1 0 0 0 0
44 Latvia 4 0 0 0 1 0 0 0 1 0 1 0 1 0 0
45 Romania 3 0 0 0 0 1 0 0 2 0 0 0 0 0 0
46 Philippines 3 0 0 0 0 0 0 2 0 0 1 0 0 0 0
47 Luxembourg 3 1 1 0 0 0 1 0 0 0 0 0 0 0 0
48 Lithuania 3 0 0 0 0 1 1 0 0 0 0 0 1 0 0
49 Estonia 3 0 1 1 0 0 0 0 0 0 1 0 0 0 0
50 Cyprus 3 0 0 0 1 1 0 0 0 0 0 1 0 0 0
51 Costa Rica 3 0 0 0 0 0 0 0 0 0 0 0 0 3 0
52 Chile 3 2 1 0 0 0 0 0 0 0 0 0 0 0 0
53 Thailand 2 0 0 2 0 0 0 0 0 0 0 0 0 0 0
54 Malta 2 0 0 0 0 0 2 0 0 0 0 0 0 0 0
55 South Korea 2 0 1 0 0 0 0 1 0 0 0 0 0 0 0
56 Jersey 2 0 1 1 0 0 0 0 0 0 0 0 0 0 0
57 Iceland 2 0 0 0 0 0 1 0 0 1 0 0 0 0 0
58 Uruguay 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0
59 Tunisia 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0
60 Tajikistan 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0
61 Svalbard and Jan Mayen 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0
62 Serbia 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0
63 Puerto Rico 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0
64 Peru 1 0 0 0 0 0 0 0 0 0 0 0 1 0 0
65 Namibia 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0
66 Martinique 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0
67 Mongolia 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0
68 Morocco 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0
69 Liechtenstein 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0
70 Cambodia 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0
71 Dominican Republic 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0
72 Cuba 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0
73 Antarctica 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0
74 United Arab Emirates 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0

Coordinates reached

# Country Σ 08 09 10 11 12 13 14 15 16 17 18 19 20 21
1 United States of America 3759 397 590 427 267 436 432 279 224 174 123 99 91 145 75
2 Germany 3551 155 447 240 293 274 247 352 329 213 162 197 227 233 182
3 United Kingdom 1122 26 101 84 95 131 80 44 284 161 40 33 24 19 0
4 Finland 559 16 20 49 32 31 82 87 61 41 31 24 25 43 17
5 Australia 496 77 69 45 35 54 59 21 24 22 20 11 15 24 20
6 Canada 377 61 76 81 47 28 20 14 7 5 9 12 4 9 4
7 Sweden 361 19 45 49 66 109 23 14 6 5 4 1 7 8 5
8 Netherlands 294 31 13 6 6 43 18 33 34 25 24 16 15 19 11
9 Switzerland 206 5 13 14 26 36 51 13 12 10 3 2 1 16 4
10 France 138 6 14 5 8 13 11 12 3 5 7 2 5 22 25
11 New Zealand 128 13 7 24 12 10 3 14 16 8 5 9 3 3 1
12 Poland 123 2 3 14 6 11 24 11 20 4 7 6 4 8 3
13 Austria 109 2 3 4 3 0 14 45 19 8 5 2 1 1 2
14 Russia 73 0 0 1 1 18 32 5 2 3 1 0 1 4 5
15 Norway 67 13 1 19 8 15 0 4 3 0 0 0 0 2 2
16 Spain 63 1 5 3 2 7 7 4 4 2 0 4 1 0 23
17 Israel 61 0 5 0 1 5 4 1 0 0 11 23 8 1 2
18 Italy 46 1 4 5 4 7 9 6 7 1 0 1 0 0 1
19 Czechia 45 4 7 5 5 7 2 2 12 0 0 1 0 0 0
20 Denmark 32 4 4 2 2 3 3 3 3 1 0 0 2 3 2
21 Belgium 32 3 4 3 3 7 2 2 2 1 2 2 0 1 0
22 Singapore 27 3 1 0 5 3 4 2 0 2 4 1 0 1 1
23 Bulgaria 25 0 0 3 8 6 3 5 0 0 0 0 0 0 0
24 Argentina 24 0 0 0 0 1 1 3 14 3 1 1 0 0 0
25 Hungary 17 4 1 0 0 0 2 2 5 2 0 0 1 0 0
26 Japan 14 0 6 3 0 4 0 0 1 0 0 0 0 0 0
27 Indonesia 11 0 2 0 1 0 1 1 1 3 1 0 1 0 0
28 India 10 0 0 8 0 0 2 0 0 0 0 0 0 0 0
29 Ireland 8 0 4 1 2 1 0 0 0 0 0 0 0 0 0
30 Brazil 8 3 0 0 1 0 0 0 1 1 1 1 0 0 0
31 Slovakia 7 1 0 1 0 0 0 0 4 1 0 0 0 0 0
32 Slovenia 7 1 1 1 1 2 0 1 0 0 0 0 0 0 0
33 Mexico 6 1 3 1 0 0 0 0 0 0 0 0 0 0 1
34 China 6 0 0 4 0 1 0 0 0 0 0 0 0 0 1
35 South Africa 5 0 2 0 1 1 0 0 0 0 0 1 0 0 0
36 Greece 5 0 0 0 0 2 0 1 1 0 0 0 0 1 0
37 Ukraine 4 1 0 0 0 0 0 0 0 0 0 0 0 1 2
38 Portugal 4 0 1 0 1 0 1 0 0 0 1 0 0 0 0
39 Latvia 4 0 0 0 1 0 0 0 1 0 1 0 1 0 0
40 Croatia 4 0 0 0 0 0 0 1 3 0 0 0 0 0 0
41 Nepal 3 0 0 2 1 0 0 0 0 0 0 0 0 0 0
42 Malaysia 3 0 0 0 0 2 0 0 0 0 1 0 0 0 0
43 international waters 2 0 0 0 0 0 0 0 0 0 0 0 1 1 0
44 Romania 2 0 0 0 0 1 0 0 1 0 0 0 0 0 0
45 Philippines 2 0 0 0 0 0 0 1 0 0 1 0 0 0 0
46 Malta 2 0 0 0 0 0 2 0 0 0 0 0 0 0 0
47 Luxembourg 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0
48 Jersey 2 0 1 1 0 0 0 0 0 0 0 0 0 0 0
49 Iceland 2 0 0 0 0 0 1 0 0 1 0 0 0 0 0
50 Estonia 2 0 0 1 0 0 0 0 0 0 1 0 0 0 0
51 Cyprus 2 0 0 0 1 1 0 0 0 0 0 0 0 0 0
52 Chile 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0
53 Turkey 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0
54 Tunisia 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0
55 Tajikistan 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0
56 Thailand 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0
57 Svalbard and Jan Mayen 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0
58 Serbia 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0
59 Lithuania 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0
60 Liechtenstein 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0
61 South Korea 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0
62 Costa Rica 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0
63 Antarctica 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0
64 United Arab Emirates 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0

Source code

The following program generates this page:

#!/bin/bash

# Copyright 2021 Fippe
# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

api="https://geohashing.site/api.php?format=json"
expandAPI="$api&action=expandtemplates&prop=wikitext&text"
categoryAPI="$api&action=query&list=categorymembers&cmprop=title&cmlimit=500&cmtitle=Category"
transcludedAPI="$api&action=query&prop=transcludedin&tiprop=title&tilimit=500&titles"

dir="/tmp/geohashingstats"
mkdir -p "$dir"
currentyear=$(date +%Y)

function gen {
    date -u +"The following table shows countries by their number of reached and total expeditions as of %F %T UTC. __TOC__"
    echo "==Methodology and Limitations=="
    echo -e "For the purpose of this list, a country is defined as anything that has a [[wikipedia:ISO 3166-1|ISO 3166-1]] code.\n\nThis page is generated by looking where [[:Category:Location templates|location templates]] are transcluded, and at the [[:Category:Expeditions|expeditions category]] and the [[:Category:Coordinates reached|coordinates reached category]]. This page is only as good as those categories.\n\nCheck out the [[#Source code|program's source code]]."
    
    codes=$(curl -s "$categoryAPI:Location_templates" | jq -r ".query.categorymembers[].title" | grep "/" | cut -d "/" -f 2 | while read -r code
        do echo "$code~%7B%7Blocation/$code%7D%7D"
        
        echo -n > "$dir/$code"
        ticontinue="0"
        while [ "$ticontinue" != "null" ]
            do curl -so "$dir/tmp" "$transcludedAPI=Template:Location/$code&tinamespace=0&ticontinue=$ticontinue"
            ticontinue=$(cat "$dir/tmp" | jq -r ".continue.ticontinue")
            cat "$dir/tmp" | jq -r ".query.pages[].transcludedin[].title" >> "$dir/$code"
        done
        rm "$dir/tmp"
    done | tr "\n" ";")
    
    curl -s "$expandAPI=$codes" | jq -r ".expandtemplates.wikitext" | tr ";~" "\n;" | grep -vx "" > "$dir/countries"
    
    for category in "Expeditions" "Coordinates_reached"
        do echo "==${category/_/ }=="
        
        echo -n > "$dir/$category"
        cmcontinue="0"
        while [ "$cmcontinue" != "null" ]
            do curl -so "$dir/tmp" "$categoryAPI:$category&cmcontinue=$cmcontinue"
            cmcontinue=$(cat "$dir/tmp" | jq -r ".continue.cmcontinue")
            cat "$dir/tmp" | jq -r ".query.categorymembers[].title" >> "$dir/$category"
        done
        rm "$dir/tmp"
       
        cat "$dir/countries" | while IFS=';' read -r code country
            do grep -cxf "$dir/$code" "$dir/$category" | tr "\n" " "
            echo "$code $country"
        done > "$dir/$category-countries"

        echo '{|class="wikitable sortable center zebra"'
        echo -n '!#!!Country!!Σ'
        
        for year in $(seq 2008 $currentyear)
            do echo -n '!!'"${year:2:2}"
        done
        sort -nr "$dir/$category-countries" | grep -v "^0" | nl | while read -r rank total code country
            do echo -en "\n|-\n|$rank||[[:Category:Expeditions in $country|$country]]||$total" | sed -e "s/|the /|/"
            
            for year in $(seq 2008 $currentyear)
                do cur=$(grep -xf "$dir/$code" "$dir/$category" | grep -c "^$year")
                echo -n "||$cur"
            done
        done
        echo -e "\n|}"
    done
    echo "==Source code=="
    echo "The following program generates this page:<pre"">$(cat "$0")</pre"">"
    echo "[[Category:Fun stuff]]"
}

gen | tee "$dir/mostactivecountries.wiki"