Most active countries

From Geohashing
Revision as of 00:04, 13 February 2022 by FippeBot (talk | contribs) (updating stats)

The following table shows countries by their number of reached and total expeditions as of 2022-02.

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 22
1 United States of America 5174 630 767 574 371 609 577 348 288 235 156 144 120 195 145 15
2 Germany 4208 186 509 283 333 314 290 410 368 248 186 219 257 254 326 25
3 United Kingdom 1375 48 124 105 113 167 98 52 327 185 46 39 29 31 7 4
4 Australia 712 97 102 54 40 98 80 29 35 29 24 15 17 26 51 15
5 Finland 620 20 23 52 35 35 92 92 63 49 33 26 27 45 25 3
6 Canada 526 91 120 107 56 36 29 20 11 6 10 12 5 16 6 1
7 Sweden 415 26 49 60 77 118 26 14 8 5 4 1 8 13 6 0
8 Netherlands 382 42 16 9 10 52 22 42 45 34 28 18 20 22 19 3
9 Switzerland 232 6 16 14 32 41 55 14 12 11 3 2 1 18 7 0
10 France 182 8 18 7 11 15 14 14 3 6 10 2 7 24 38 5
11 Poland 149 3 4 18 6 13 30 12 22 4 8 7 4 8 9 1
12 New Zealand 149 18 7 28 16 12 5 15 16 8 7 10 3 3 1 0
13 Austria 127 3 4 5 3 2 15 47 26 8 5 2 1 2 4 0
14 Spain 105 2 5 4 2 8 10 4 4 2 0 5 1 1 49 8
15 Israel 103 1 10 0 3 6 4 1 0 0 13 26 9 5 23 2
16 Russia 102 0 0 1 2 21 41 6 2 4 3 0 1 4 17 0
17 Norway 87 20 2 27 10 16 0 4 3 0 0 0 1 2 2 0
18 Italy 55 1 4 8 4 9 12 6 7 1 0 1 0 0 2 0
19 Czechia 53 5 7 6 5 8 4 4 13 0 0 1 0 0 0 0
20 Denmark 43 7 5 3 3 4 3 3 5 1 0 0 2 5 2 0
21 Belgium 40 6 5 4 3 9 3 2 2 1 2 2 0 1 0 0
22 Singapore 37 7 2 0 7 4 5 2 0 2 5 1 0 1 1 0
23 Argentina 29 0 0 0 0 2 2 3 17 3 1 1 0 0 0 0
24 Bulgaria 27 0 0 4 8 6 3 6 0 0 0 0 0 0 0 0
25 Hungary 23 9 1 0 0 0 2 2 5 3 0 0 1 0 0 0
26 Japan 16 0 6 4 0 5 0 0 1 0 0 0 0 0 0 0
27 Indonesia 15 0 3 0 1 1 1 2 1 4 1 0 1 0 0 0
28 China 12 0 0 6 1 1 0 0 1 0 0 0 0 0 1 2
29 Brazil 12 3 0 0 1 1 0 0 1 1 1 3 0 1 0 0
30 India 11 0 0 8 0 1 2 0 0 0 0 0 0 0 0 0
31 Ireland 10 0 4 1 2 2 1 0 0 0 0 0 0 0 0 0
32 Slovenia 9 2 1 1 1 2 0 1 0 1 0 0 0 0 0 0
33 Mexico 9 1 5 1 0 0 0 1 0 0 0 0 0 0 1 0
34 Slovakia 8 1 0 2 0 0 0 0 4 1 0 0 0 0 0 0
35 international waters 7 2 0 1 0 1 1 0 0 0 0 0 1 1 0 0
36 Ukraine 7 1 0 0 0 0 0 0 0 0 0 0 0 1 5 0
37 Greece 7 0 0 0 0 2 0 2 1 1 0 0 0 1 0 0
38 South Africa 6 0 2 0 1 1 0 0 0 0 0 2 0 0 0 0
39 Croatia 6 0 0 0 0 1 0 2 3 0 0 0 0 0 0 0
40 Turkey 5 0 3 1 0 0 0 0 0 0 0 1 0 0 0 0
41 Portugal 5 0 1 0 1 0 1 0 0 0 1 0 0 1 0 0
42 Nepal 5 0 0 3 2 0 0 0 0 0 0 0 0 0 0 0
43 Malaysia 4 0 0 1 0 2 0 0 0 0 1 0 0 0 0 0
44 Latvia 4 0 0 0 1 0 0 0 1 0 1 0 1 0 0 0
45 Romania 3 0 0 0 0 1 0 0 2 0 0 0 0 0 0 0
46 Philippines 3 0 0 0 0 0 0 2 0 0 1 0 0 0 0 0
47 Luxembourg 3 1 1 0 0 0 1 0 0 0 0 0 0 0 0 0
48 Estonia 3 0 1 1 0 0 0 0 0 0 1 0 0 0 0 0
49 Cyprus 3 0 0 0 1 1 0 0 0 0 0 1 0 0 0 0
50 Costa Rica 3 0 0 0 0 0 0 0 0 0 0 0 0 2 1 0
51 Chile 3 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0
52 Thailand 2 0 0 2 0 0 0 0 0 0 0 0 0 0 0 0
53 Malta 2 0 0 0 0 0 2 0 0 0 0 0 0 0 0 0
54 Lithuania 2 0 0 0 0 1 1 0 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 0
56 Jersey 2 0 1 1 0 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 0
58 Uruguay 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
59 Tanzania 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0
60 Tunisia 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0
61 Tajikistan 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0
62 San Marino 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0
63 Svalbard and Jan Mayen 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
64 Serbia 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0
65 Puerto Rico 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0
66 Peru 1 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0
67 Namibia 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0
68 Martinique 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0
69 Morocco 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
70 Liechtenstein 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
71 Cambodia 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0
72 Dominican Republic 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0
73 Cuba 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0
74 Antarctica 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
75 United Arab Emirates 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0

Coordinates reached

# Country Σ 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22
1 United States of America 3828 402 590 427 267 437 436 279 228 177 125 100 95 145 109 11
2 Germany 3707 155 447 240 293 275 251 353 331 218 166 200 228 237 291 22
3 United Kingdom 1137 26 101 84 95 132 82 44 284 162 40 33 24 21 5 4
4 Finland 582 16 20 49 32 31 82 87 62 49 33 26 26 43 23 3
5 Australia 539 77 69 45 35 54 59 22 25 24 20 11 15 24 45 14
6 Canada 382 61 76 81 47 29 20 14 7 5 9 12 4 11 5 1
7 Sweden 364 19 45 49 66 110 24 14 7 5 4 1 7 8 5 0
8 Netherlands 305 31 13 6 6 43 19 33 34 25 24 16 16 19 17 3
9 Switzerland 209 5 14 14 26 36 52 13 12 10 3 2 1 16 5 0
10 France 150 6 14 5 8 13 11 12 3 5 7 2 5 22 34 3
11 Poland 129 2 3 14 6 11 24 11 20 4 7 6 4 8 8 1
12 New Zealand 128 13 7 24 12 10 3 14 16 8 5 9 3 3 1 0
13 Austria 111 2 3 4 3 0 14 45 20 8 5 2 1 1 3 0
14 Russia 82 0 0 1 1 19 33 5 2 3 1 0 1 4 12 0
15 Spain 82 1 5 3 2 7 7 4 4 2 0 4 1 0 37 5
16 Israel 81 0 5 0 2 5 4 1 0 0 11 23 8 3 17 2
17 Norway 67 13 1 19 8 15 0 4 3 0 0 0 0 2 2 0
18 Italy 46 1 4 5 4 7 9 6 7 1 0 1 0 0 1 0
19 Czechia 45 4 7 5 5 7 2 2 12 0 0 1 0 0 0 0
20 Denmark 33 4 4 2 2 3 3 3 4 1 0 0 2 3 2 0
21 Belgium 32 3 4 3 3 7 2 2 2 1 2 2 0 1 0 0
22 Singapore 27 3 1 0 5 3 4 2 0 2 4 1 0 1 1 0
23 Bulgaria 25 0 0 3 8 6 3 5 0 0 0 0 0 0 0 0
24 Argentina 24 0 0 0 0 1 1 3 14 3 1 1 0 0 0 0
25 Hungary 17 4 1 0 0 0 2 2 5 2 0 0 1 0 0 0
26 Japan 14 0 6 3 0 4 0 0 1 0 0 0 0 0 0 0
27 Indonesia 12 0 2 0 1 0 1 1 1 4 1 0 1 0 0 0
28 India 10 0 0 8 0 0 2 0 0 0 0 0 0 0 0 0
29 Brazil 9 3 0 0 1 0 0 0 1 1 1 2 0 0 0 0
30 Ireland 8 0 4 1 2 1 0 0 0 0 0 0 0 0 0 0
31 China 8 0 0 4 0 1 0 0 0 0 0 0 0 0 1 2
32 Slovakia 7 1 0 1 0 0 0 0 4 1 0 0 0 0 0 0
33 Slovenia 7 1 1 1 1 2 0 1 0 0 0 0 0 0 0 0
34 Ukraine 6 1 0 0 0 0 0 0 0 0 0 0 0 1 4 0
35 Mexico 6 1 3 1 0 0 0 0 0 0 0 0 0 0 1 0
36 South Africa 5 0 2 0 1 1 0 0 0 0 0 1 0 0 0 0
37 Greece 5 0 0 0 0 2 0 1 1 0 0 0 0 1 0 0
38 Portugal 4 0 1 0 1 0 1 0 0 0 1 0 0 0 0 0
39 Latvia 4 0 0 0 1 0 0 0 1 0 1 0 1 0 0 0
40 Croatia 4 0 0 0 0 0 0 1 3 0 0 0 0 0 0 0
41 Nepal 3 0 0 2 1 0 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 0
43 international waters 2 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0
44 Romania 2 0 0 0 0 1 0 0 1 0 0 0 0 0 0 0
45 Philippines 2 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0
46 Malta 2 0 0 0 0 0 2 0 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 0
48 Jersey 2 0 1 1 0 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 0
50 Estonia 2 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0
51 Cyprus 2 0 0 0 1 1 0 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 0
53 Turkey 1 0 0 1 0 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 0
55 Tajikistan 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0
56 Thailand 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0
57 San Marino 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0
58 Svalbard and Jan Mayen 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
59 Serbia 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0
60 Lithuania 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
61 Liechtenstein 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
62 South Korea 1 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0
63 Costa Rica 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0
64 Antarctica 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0
65 United Arab Emirates 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0

See also

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 %Y-%m. __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 -e "==See also==\n*[[Most active users]]\n*[[Most active graticules]]\n*[[Maps and statistics]]\n==Source code=="
    echo "The following program generates this page:<pre"">$(cat "$0")</pre"">"
    echo "[[Category:Fun stuff]]"
}

gen | tee "$dir/mostactivecountries.wiki"