Template:Find country
This template is used on approximately 260,000 pages. To avoid major disruption and server load, any changes should be tested in the template's /sandbox or /testcases subpages, or in your own user subpage. The tested changes can be added to this page in a single edit. Consider discussing changes on the talk page before implementing them. |
This template uses Lua: |
Extracts from string the name of a continent or country (Africa, India, the United Kingdom etc). Returns nothing if there is no match.
Note that the country in the string must properly capitalised. "India" will be matched, but "india" or "INDIA" will be ignored.
The list of countries is hard-coded in a list in Module:Find country, based on the list in {{Football demonyms}} - the code works its way down that list in order. The "longest" form of a country name comes first, so eg "the United Kingdom" comes before "United Kingdom" and so both will be matched, but the "the" form if present will be returned first (and hence is returned by default unless the match parameter is set otherwise)
Some options allow its behaviour to be configured.
Usage
Basic usage
{{Find country|Foo}}
This usage will return the first time in string Foo which matches the correctly-capitalised name of a continent or country.
If no match is found, it returns an empty string. This allows its simple use in templates, e.g.
{{#if: {{Find country}}|<!-- do nothing if there is a match -->|This string does not include a country}}
Optional parameters
One parameter is obligatory, two optional parameters are available:
|string=value
- This forces the template to use a title other than the current page
|nomatch=value
- This parameter is used to specify a message to be generate if no match is found. For example
- Default output
{{Find country|The quick brown fox jumps over the lazy dog}}
→ - with nomatch
{{Find country|The quick brown fox jumps over the lazy dog|nomatch=No country!}}
→ No country!
- Default output
|match=number
- If multiple country names are found, this specifies which match to return, where the first match is match= 1. If a negative number is specified then a match is returned counting from the last match. Hence match = -1 is the same as requesting the last match. Defaults to 1.
- Examples:
{{Find country|Events in Bangladesh, India and Pakistan (and maybe Sri Lanka) |match=2}}
→ India{{Find country|Events in Bangladesh, India and Pakistan (and maybe Sri Lanka)|match=-2}}
→ Pakistan
TemplateData
TemplateData for Find country
Extracts a country name from a string. All parameters are optional.
Parameter | Description | Type | Status | |
---|---|---|---|---|
Search string | string | String to search for country. If left blank, the template will return a blank, the bare module will use the page name | String | optional |
Match Instance | match | If multiple countries are found, this specifies which match to return, where the first match is match= 1. If a negative number is specified then a match is returned counting from the last match. Hence match = -1 is the same as requesting the last match. Defaults to 1.
| Number | optional |
No match text | nomatch | If no countries are found, output the "nomatch" value. Defaults to blank. | String | optional |
See also
- {{Title country}} - a wrapper for this template using PAGENAME
- {{country2nationality}} - take the output of this template (or any other country name string) and generate a nationality
- {{country2continent}} - take the output of this template (or any other country name string) and generate a continent