Module:String2
| This module is rated as alpha. It is ready for third-party input, and may be used on a few pages to see if problems arise, but should be watched. Suggestions for new features or changes in their input and output mechanisms are welcome. |
The module String2 contains 4 available calls that convert strings to upper, lower, sentence or title case.
The sentence case function finds the first letter and capitalises it, so it works properly with text containing wiki-markup. Compare {{#invoke:String2|sentence|[[action game]]}} -> Action game with {{ucfirst:{{lc:[[action game]]}}}} -> action game. Piped wiki-links are handled as well: {{#invoke:String2|sentence|[[trimix (breathing gas)|trimix]]}} -> Trimix.
The title case function capitalises the first letter of each word in the text, apart from a number of short words recommended by The U.S. Government Printing Office Style Manual.
It would be useful to add further functions commonly used on strings.
Usage
{{#invoke:String2 | upper |…}}- Shifts all characters to uppercase{{#invoke:String2 | lower |…}}- Shifts all characters to lowercase{{#invoke:String2 | label |…}}- Capitalizes the first character- Although similar to magic words'
{{ucfirst:}}function, this call works even with piped wiki-links because it searches beyond leading brackets and other non-alphanumeric characters. - As of 23 February 2018, it should now also recognise when it has an html list passed to it and capitalises the first alphabetic letter beyond the list item markup (
<li>) and any piped links that may be there.
- Although similar to magic words'
{{#invoke:String2 | sentence |…}}- Capitalizes the first character and shifts the rest to lowercase{{#invoke:String2 | title |…}}- Capitalizes all words, except fora,an,the,at,by,for,in,of,on,to,up,and,as,but,or, andnor.
Parameters
The module takes one unnamed parameter comprising (or invoking as a string) the text to be converted.
Examples
| Input | Output |
|---|---|
| {{#invoke:String2| upper | abcd }} | ABCD |
| {{#invoke:String2| upper | abCD }} | ABCD |
| {{#invoke:String2| upper | ABcd }} | ABCD |
| {{#invoke:String2| upper | ABCD }} | ABCD |
| {{#invoke:String2| upper | }} | |
| {{#invoke:String2| lower | abcd }} | abcd |
| {{#invoke:String2| lower | abCD }} | abcd |
| {{#invoke:String2| lower | ABcd }} | abcd |
| {{#invoke:String2| lower | ABCD }} | abcd |
| {{#invoke:String2| lower | }} | |
| {{#invoke:String2| label | abcd }} | Abcd |
| {{#invoke:String2| label | abCD }} | AbCD |
| {{#invoke:String2| label | ABcd }} | ABcd |
| {{#invoke:String2| label | ABCD }} | ABCD |
| {{#invoke:String2| label | }} | |
| {{#invoke:String2| label | human X chromosome }} | Human X chromosome |
| {{#invoke:String2| sentence | abcd }} | Abcd |
| {{#invoke:String2| sentence | abCD }} | Abcd |
| {{#invoke:String2| sentence | ABcd }} | Abcd |
| {{#invoke:String2| sentence | ABCD }} | Abcd |
| {{#invoke:String2| sentence | [[action game]] }} | Action game |
| {{#invoke:String2| sentence | [[trimix (breathing gas)|trimix]] }} | Trimix |
| {{#invoke:String2 | sentence | {{#invoke:WikidataIB |getValue |P136 |fetchwikidata=ALL |onlysourced=no |qid=Q1396889}} }} | lua error in module:wikidataib at line 708: attempt to index field 'wikibase' (a nil value). |
| {{#invoke:String2 | sentence | {{#invoke:WikidataIB |getValue |P106 |fetchwikidata=ALL |list=hlist |qid=Q453196}} }} | lua error in module:wikidataib at line 708: attempt to index field 'wikibase' (a nil value). |
| {{#invoke:String2| sentence | }} | |
| {{#invoke:String2| title | abcd }} | Abcd |
| {{#invoke:String2| title | abCD }} | Abcd |
| {{#invoke:String2| title | ABcd }} | Abcd |
| {{#invoke:String2| title | ABCD }} | Abcd |
| {{#invoke:String2| title | }} | |
| {{#invoke:String2| title | the vitamins are in my fresh california raisins}} | The Vitamins Are in My Fresh California Raisins |
See also
Module:String for the following functions:
- len
- sub
- sublength
- match
- pos
- str_find
- find
- replace
- rep
Other templates
- {{Fixcaps}} – capitalizes or lowercases words (mostly used to repair paragraphs written by new editors in all-caps or all-lowercase {{fixcaps|pLAy/tHE/GamE}} → Play the Game
- {{Capitalization}} – banner-style template indicating an article needs capitalization cleanup
- {{R from other capitalisation}} – for categorizing WP:Redirects from titles to article (or other pages) where the redirect is just a different capitalization
- {{Template capitalization}} – ??
- Module:String2
Magic words that rewrite the output (copy-paste will get the text as displayed, not as entered):
{{lc:}}– lower case output of the full text{{uc:}}– upper case output of the full text{{lcfirst:}}– lower case output of the first character only{{ucfirst:}}– upper case output of the first character only
local p = {}
p.upper = function(frame)
local s = mw.text.trim(frame.args[1] or "")
return string.upper(s)
end
p.lower = function(frame)
local s = mw.text.trim(frame.args[1] or "")
return string.lower(s)
end
p.sentence = function (frame )
local s = mw.text.trim( frame.args[1] or "" )
local s1 = ""
-- if it's a list chop off and (store as s1) everything up to the first <li>
local lipos = string.find(s, "<li>" )
if lipos then
s1 = string.sub(s, 1, lipos + 3)
s = string.sub(s, lipos + 4)
end
-- s1 is either "" or the first part of the list markup, so we can continue
-- and prepend s1 to the returned string
if string.find(s, "^%[%[[^|]+|[^%]]+%]%]") then
-- this is a piped wikilink, so we capitalise the text, not the pipe
local b, c = string.find(s, "|%A*%a") -- find the first letter after the pipe
return s1 .. string.sub(s, 1, c-1) .. string.upper(string.sub(s, c, c)) .. string.sub(s, c+1)
end
local letterpos = string.find(s, '%a')
if letterpos then
local first = string.sub(s, 1, letterpos - 1)
local letter = string.sub(s, letterpos, letterpos)
local rest = string.sub(s, letterpos + 1)
return s1 .. first .. string.upper(letter) .. string.lower(rest)
else
return s1 .. s
end
end
p.title = function (frame )
-- http://grammar.yourdictionary.com/capitalization/rules-for-capitalization-in-titles.html
-- recommended by The U.S. Government Printing Office Style Manual:
-- "Capitalize all words in titles of publications and documents,
-- except a, an, the, at, by, for, in, of, on, to, up, and, as, but, or, and nor."
local alwayslower = {['a'] = 1, ['an'] = 1, ['the'] = 1,
['and'] = 1, ['but'] = 1, ['or'] = 1, ['for'] = 1,
['nor'] = 1, ['on'] = 1, ['in'] = 1, ['at'] = 1, ['to'] = 1,
['from'] = 1, ['by'] = 1, ['of'] = 1, ['up'] = 1 }
local res = ''
local s = mw.text.trim( frame.args[1] or "" )
local words = mw.text.split( s, " ")
for i, s in ipairs(words) do
s = string.lower( s )
if( i > 1 ) then
if( alwayslower[s] ~= 1 ) then
s = mw.getContentLanguage():ucfirst(s)
end
else
s = mw.getContentLanguage():ucfirst(s)
end
words[i] = s
end
return table.concat(words, " ")
end
p.label = function (frame )
-- Capitalizing only first letter for fetched Wikidata labels.
-- Wikidata English labels generally begin with a lowercase letter. [[:d:Help:Label#Capitalization]]
local s = mw.text.trim( frame.args[1] or "" )
if string.find(s, "^%[%[[^|]+|[^%]]+%]%]") then
-- this is a piped wikilink, so we capitalise the text, not the pipe
local b, c = string.find(s, "|%A*%a") -- find the first letter after the pipe
return string.sub(s, 1, c-1) .. string.upper(string.sub(s, c, c)) .. string.sub(s, c+1)
end
local letterpos = string.find(s, '%a')
if letterpos then
local first = string.sub(s, 1, letterpos - 1)
local letter = string.sub(s, letterpos, letterpos)
local rest = string.sub(s, letterpos + 1)
return first .. string.upper(letter) .. rest
else
return s
end
end
return p
