Help talk:Extension:ParserFunctions

Jump to: navigation, search

#time: and Daylight Savings[edit]

Is there any flag for DST? Is there any intent to add a flag for this in the future if it currently doesn't exist? Thank you. -- ShoeMaker   ( Contributions Message )   18:30, 9 November 2012 (UTC)

As I see, if it wasn't, now it exist, but doesn't work anyway (#time: I). Ядерный Трамвай (talk) 14:43, 9 September 2016 (UTC)

Square root and other questions[edit]

I had 2 questions about the {{#expr:}} and the {{#ifexpr:}} parser functions:

  1. Is it possible to add a square root to those functions? using the sign √ in a formula doesnt work to me.
  2. Also, what do the != and the <> logic keys do? 14:38, 26 November 2012 (UTC)

Oh, i see that != make negative solutions possitive, but i still need the square root thing. 14:49, 26 November 2012 (UTC)
 ! in front of any conditional punctuation means NOT, so != is NOT EQUAL. As far as your question about sqr roots, you could build a (set of) template(s) like -- 15:08, 26 November 2012 (UTC)
tHANK YOU 15:59, 26 November 2012 (UTC)
That template does not work. sqrt is not recognized. How can I get a square root calculation?
King Dragonhoff 12 December 2014
Templates were never supposed to be some kind of "programming language", and the whole idea of Tim Starling's parser functions was to offer a faster alternative to template hacks ignoring this rule. State of the art is to use Scribunto math in the module namespace, if the parser functions are not good enough for your purposes. –Be..anyone (talk) 00:36, 13 December 2014 (UTC)
I created this template. It can find any root of a number.
King Dragonhoff 27 February 2015
Write the root as an exponential power: √X = X^(1/2). Or, in general, X^(1/Y) for the Y-th root of X. --Theaitetos (talk) 22:06, 27 February 2015 (UTC)

#time and full month names[edit]

Hi, I am apparently not seeing any indication of what any underlying support files are called.
The F operator returns a full month name, so 12 produces "December".
Which file houses the actual "December" string?
At my home wiki, it is returning the wrong string.
Thanks, Varlaam (talk) 05:41, 30 November 2012 (UTC)

On "my" wiki, I believe it uses MediaWiki:December and/or MediaWiki:December-gen, but I'm not entirely sure. If you would like to link your an example on your home wiki so I can see what it is returning, I would be happy to take a look and try to help you fix it. -- ShoeMaker   ( Contributions Message )   22:42, 2 January 2013 (UTC)

Test for existence of Month or Day in Date string?[edit]

Is there some way to test if a day or month was part of a date string?

For example, {{#time r|2003}} only contains a year, but returns a string formatted with the current month and day. I'd like to be able to return empty if passed on month or day (e.g. like {{#time n|2003}}, but returning empty if there is no month part of the date). Curly Turkey (talk) 23:57, 31 December 2012 (UTC)

I want to help you, but I'm not entirely sure what you are asking for.
{{#time:r|2003}} returns Mon, 20 Oct 2003 00:00:00 +0000
{{#time:n|2003}} returns 10
I'm assuming you are hoping to use this as part of a template that will have values passed in to it, is that correct? If so, what is your list of arguments, what do you hope the template can do, and do you have a link to the template creation sandbox or wherever that you have started to make this so I can take a peek and hopefully understand what you want. -- ShoeMaker   ( Contributions Message )   22:52, 2 January 2013 (UTC)

See also Scribunto ?[edit]

Now, we have modules in scribunto/Lua and the syntax to call them is " {{#invoke| ". Then users will try to search them here and we could add Extension:Scribunto to "See also" paragraph ? --Rical (talk) 18:13, 11 May 2013 (UTC)

I think you should create a section Extension:Scribunto/Lua reference manual#invoke on the extension page, since that should bring this section to the top of the search results when people search "invoke". --Theaitetos (talk) 22:11, 12 May 2013 (UTC)

How can we do a sum ?[edit]

Cat Fruit
Total sum

Hello ! Is there a function to do the sum of A+B+C+D+E ? Historymating (talk) 11:42, 8 June 2013 (UTC)

  1. expr can calculate sums. But it's not possible for any function to process things, that are not in the input area of the function itself. --Theaitetos (talk) 13:58, 28 June 2013 (UTC)

Unwanted whitespace in article from #switch[edit]

I'm using a template whose entirety is just a switch statement to transclude one of two possible subtemplates. However, ParserFunctions seems to be adding an extra line of whitespace before the result of the switch statement when I use it this way. Is there a way to remove this whitespace?--Idran (talk) 01:46, 28 June 2013 (UTC)

Hello Idran. You should first check if the template adds the white space (line break). If you want to be strict on what gets transcluded via the template make sure you put everything that needs to be transcluded between <includeonly> tags. Below an example.
== Any Template documentation ==
* Bla bla 1
* Bla bla 2
* Bla bla 3</noinclude><includeonly>{{#switch:baz|foo=Foo|baz=Baz|Bar}}</includeonly>
If you don't do that you could easily transclude a line break to a page. --Jongfeli (talk) 08:34, 28 June 2013 (UTC)
  • I disagree with Jongfeli. en:Help:Transclusion#Markup has an informative section on how transclusion and the various include tags work. Idran if you could post the markup from your template here, I would be happy to help you make it work as you expect. I'm thinking the #switch might not be needed if there are only two outcomes and maybe an #ifeq would work better. Technical 13 (talk) 12:13, 28 June 2013 (UTC)
    • Actually while I was copying the code of the templates here, I noticed exactly what the problem was; I had an includeonly section in the subtemplates that I hadn't realized was adding an unwanted linebreak, and I didn't notice it because I was focusing my attention on the template itself. Apologies for the unnecessary responses!-- 19:26, 28 June 2013 (UTC)
    • Whoops, didn't notice I wasn't logged in; that was me above.--Idran (talk) 19:59, 28 June 2013 (UTC)

Hebrew calendar (Jewish calendar) date as date/time object[edit]

Is there a way to enter a Hebrew calendar date as a date/time object in the #time: function? In other words, I know how to get a Hebrew calendar date out by entering a Gregorian date/time object in the function. Can I do it the other way around? Thanks. StevenJ81 (talk) 01:34, 24 July 2013 (UTC)

HTML and Parser functions[edit]

I have tried to use Parser functions with HTML(More accurately CSS), but there is some conflict made by the ">" operator. What can I do in order to solve the problem? Thanks. 22:40, 9 August 2013 (UTC)

  • Without you showing us the code in question that you are getting errors for, the first suggestion I may offer is to use &lt; and &gt; to achieve < and > respectively. Technical 13 (talk) 23:37, 9 August 2013 (UTC)
For example, using a style tag...
<div style='/*abunchofrandomstuff*/;transform:rotate({{#expr: 360 - 180 + {{#ifexpr: {{{degree|180})} > 180 | 180 | {{{degree|180}}}}}}}deg);'></div>

The > makes the tag closed and caused errors, so what should I do? 10:00, 14 August 2013 (UTC)

First, there is a significant typo when closing the parameter degree with })} instead of }}}: <{{#ifexpr: {{{degree|180})} > 180
If that doesn't fix the problem, try turning the ifexpr around: {{#ifexpr: 180 < {{{degree|180}}}. --Theaitetos (talk) 18:29, 19 August 2013 (UTC)

Bug in time code?[edit]

"Feb" is getting reported as 3 for format letter "n" (see below) Esjs (talk) 16:03, 30 August 2013 (UTC)

{{#time:n|Jan}} {{#time:n|Feb}} {{#time:n|Mar}} {{#time:n|Apr}} {{#time:n|May}} {{#time:n|Jun}}
1 2 3 4 5 6
{{#time:n|Jul}} {{#time:n|Aug}} {{#time:n|Sep}} {{#time:n|Oct}} {{#time:n|Nov}} {{#time:n|Dec}}
7 8 9 10 11 12

using #ifexist to check for files in templates[edit]


I'm using something like the above in a template to check for files. It works fine, but if files corresponding to {{PAGENAME}}.png are added after the pages transcluding this template is edited, the files show up in Unused Files list and the File:{{PAGENAME}}.png links show up in Wanted Pages list, not Wanted Files list. Purging any of the relevant pages doesn't fix it. Only editing the pages which have the template transluded updates the link lists. the Is there a way around this bug? - 04:56, 8 October 2013 (UTC)

Cleanup number with thousands separator[edit]

When calculating with a number like {{PAGESIZE}}, a number with thousands separator (comma in enwiki) is returned like 28,123. Is there a cleanup function, and shouldn't we add that to this helppage? -DePiep (talk) 11:46, 7 November 2013 (UTC)

You were looking for Help:Magic words#Technical_metadata_of_another_page. Some magic words yielding whole numbers have a parameter R, e.g., {{PAGESIZE:Project:About}} gives 8,389, and {{PAGESIZE:Project:About|R}} gives 8389. –Be..anyone (talk) 00:56, 13 December 2014 (UTC)

Undocumented feature of #time[edit]

Hello, I was just trying something that I thought might work, and it did, despite it not being listed here. it might be useful to add such a note to the page. (if it is noted, then my apologies, but it wasn't obvious)

{{#time: U | second Sunday of March 10:00 }}

Which displays the second sunday in march at 10:00. - 09:34, 16 November 2013 (UTC)

This is documented. Go to Help:Extension:ParserFunctions#.23time and scroll down until you see "Minutes and seconds" in the table to the right. Allen4names (talk) 15:17, 5 February 2014 (UTC)


How can I test if a parameter starts with a parenthesis? I wish to add parentheses to a number template when the uncertainty is input as ±x, but not when it's formatted as (x). So I'd like to test if the first character of the string is a parenthesis, or if the string contains a parenthesis, and only add parentheses when this is false. Kwamikagami (talk) 07:43, 7 February 2014 (UTC)

Thanks. I'm working on WP, which has them installed, doesn't it? Kwamikagami (talk) 08:20, 7 February 2014 (UTC)
  • The English Wikipedia has Extension:Scribunto installed. There is also already a string functions module written which you can see on en:Module:String. What you'll want to use to see if "(" is the first character is {{#invoke:String|sub|{{{1|whatever you are passing in to test}}}|1|1}} Technical 13 (talk) 10:24, 7 February 2014 (UTC)
Thanks! I didn't even know that was there. I've always come here. But what they have isn't enough for me to follow: If param A begins with / contains (, I want to do X, otherwise Y. What I have is (for param 2):
{{#ifeq: {{#invoke:String|sub|{{{2|}}}|1|1}}|"("|| [thing to do if no "("] }}
but it has no effect. Kwamikagami (talk) 11:22, 7 February 2014 (UTC)
  • {{#ifeq: {{#invoke:String|sub|(x)|1|1}}|(|There is a "("| There is no "(" }}
There is no "("
  • {{#ifeq: {{#invoke:String|sub|±x|1|1}}|(|There is a "("| There is no "(" }}
There is no "("
I don't understand: It's false whether there's a parenthesis or not. But someone else found a way of doing this with just {{#if:{{#ifexpr:0{{{2}}}}}|, so I won't need this after all. (I was trying to do it on my own so someone else wouldn't have to.) Thanks, though. Kwamikagami (talk) 18:47, 7 February 2014 (UTC)
  • Yeah, it wasn't earlier. Using the English Wikipedia version of the module, it works, however, using that version broke multiple templates on this wiki that will need to be updated before I can update the module. You'll have to take my word for it that it will work properly on the English Wikipedia. :/ Technical 13 (talk) 21:48, 7 February 2014 (UTC)


how can i add tags to my template so if i have only 1 tag it will not display empty spaces or tag icons without words? (sometimes i have a few tags) — Preceding unsigned comment added by (talkcontribs) 13 March 2014(2014-03-13) 22:07:46 (UTC)

Unwanted line breaks in if statements[edit]


I have the following in a table:

! Website Address
| [[Webpage::{{{Website|}}}]]}}}}
{{#if:{{{Facebook ID|}}}|{{#!:
! Facebook
| [[Facebook ID::{{{Facebook ID|}}}]]}}}}
{{#if:{{{Twitter ID|}}}|{{#!:
! Twitter hashtag
| [[Twitter ID::{{{Twitter ID|}}}]]}}}}

At the end of each #if block I get a


in the HTML leading to ugly line breaks if one or more if the fields is hidden.

Any ideas?

Thanks. — Preceding unsigned comment added by Mitchelln (talkcontribs) 14 March 2014(2014-03-14) 11:38:57 (UTC)

How to insert Vertical Bar (|) in if statement[edit]

For example, if I want to insert {{{4}}}||{{{5}}} if {{{4}}} exists, I should use . However, the program will think the Vertical Bars are part of the statement. --Kuwaity26 (talk) 18:35, 18 June 2014 (UTC)

See Help:Template#A parameter value containing a pipe character. --Theaitetos (talk) 18:48, 18 June 2014 (UTC)

Maybe an error in documentation[edit]

I don't know if I misunderstood what is written, but I really don't understand what means the sentence: "For preventing trimming then- and else-parts, see m:Template:If. Some people use also <nowiki> </nowiki> instead of spaces.". AFAIK, the <nowiki> can not be used to prevent the trimming of spaces. Can someone clarify this part for me? --Diego Queiroz (talk) 17:36, 4 October 2014 (UTC)

Actually it does work:
I think{{#if: therefore |<nowiki></nowiki> I am <nowiki></nowiki>}}Descartes.
results in
I think I am Descartes.
Without the nowiki-Tags, you would get:
I thinkI amDescartes.
The nowiki-Tags prevent that the whitespace at the beginning and end of the 3rd (then) and 4th (else) parameter gets trimmed. Or you can build a template like the one over at Metawiki: m:template:if. --Theaitetos (talk) 18:40, 4 October 2014 (UTC)
Thanks for the answer. Now I got it, but in the current text, it is not clear that it only works for a single space. My interpretation was that it allows me to use multiple spaces, which is not true. In addition, it would be good to suggest the use of &nbsp; (or even &#32; for a breakable space), like these:
  • I think{{#if: therefore | &nbsp;&nbsp;&nbsp;I am&nbsp;&nbsp;&nbsp; }}Descartes.I think   I am   Descartes. (non-breakable, allow multiple spaces)
  • I think{{#if: therefore | &#32;&#32;&#32;I am&#32;&#32;&#32; }}Descartes.I think I am Descartes. (breakable, does not allow multiple spaces)
What do you think? --Diego Queiroz (talk) 21:01, 4 October 2014 (UTC)
You're welcome.
Well, it does support multiple spaces that way, but websites in general do not display several spaces unless you specify that by CSS or something. But you are right to change the text to clarify the meaning. --Theaitetos (talk) 22:40, 4 October 2014 (UTC)
YesY Done [1] --Diego Queiroz (talk) 23:57, 18 November 2014 (UTC)


I've disabled the new #ifex section with an includeonly-hack (to bypass the translation XML-comments), because all examples supposed to show how it works fail, and the given reference on Meta (in essence as it was in 2007 created by Patrick) doesn't mention #ifex. If that's for real, where and when was it introduced (and please remove my hack if it's real.) –Be..anyone (talk) 14:51, 17 November 2014 (UTC)

No new insights, I'll remove my hack + the hidden #ifex content. –Be..anyone (talk) 23:53, 30 November 2014 (UTC)

Incorrect information on zero padding in #time[edit]

Currently the doc lists that if you zero pad a year, it will still be interpreted as one of the 0-99 special years, although both in my usage on another wiki and in the doc it can be clearly seen that is false now (it now acts as the years 0-99). Since this is true, should the doc get updated? --KnightMiner (talk) 23:07, 18 January 2015 (UTC)

You are right. Done. --Diego Queiroz (talk) 23:33, 18 January 2015 (UTC)


The text implies that:

{{#ifeq: {{FULLPAGENAME: L'Aquila}} | L'Aquila | equal | not equal}}

Should return not equal due to ' becoming an escape character.

However if we try it:


{{#ifeq: {{FULLPAGENAME: Æthelred}} | Æthelred | equal | not equal}}



And even:

{{#ifeq: {{FULLPAGENAME: 日本語}} | 日本語 | equal | not equal}}




{{#ifeq: {{FULLPAGENAME: bah_boo}} | bah_boo | equal | not equal}}

not equal

I think the example is bad, though there are a few problem cases. Adam Cuerden (talk) 17:14, 20 January 2015 (UTC)

I think the warning is obsolete. And about your last example, it is a special case related with a limitation of the software: "bah_boo" evaluates to "bah boo" (without space). Note that it is not possible to create a page with "_" in the title. --Diego Queiroz (talk) 03:50, 22 January 2015 (UTC)
  • Actually, on most wikis you have two problems with this attempt at an evaluation. First, {{FULLPAGENAME: bah_boo}} evaluates to Bah boo with an upper case B and second there is no "_". To workaround this, you need to use get the lowercase version of the pagename ( {{lc:{{FULLPAGENAME: bah_boo}}}}bah boo ), then you need to combine that with getting the Encoded version of FULLPAGENAME... {{lc:{{FULLPAGENAMEE: bah_boo}}}}bah_boo. This gives:
{{#ifeq: {{lc:{{FULLPAGENAMEE: bah_boo}}}} | bah_boo | equal | not equal}} ⇒ equal
Happy coding! — {{U|Technical 13}} (etc) 20:18, 22 January 2015 (UTC)
Good recipe, maybe only lcfirst limited to the technical issue. –Be..anyone (talk) 17:46, 23 January 2015 (UTC)
  • That's an option depending on exactly what's trying to be accomplished. Alternatively, you could make the string you are comparing against have the upper case first letter since you are expecting a page title and skip case modification all together. — {{U|Technical 13}} (etc) 22:00, 23 January 2015 (UTC)


I've added a note that it strips underscores for spaces, as this actually is rather important behaviour if you want to use it in, say, an #ifeq - we don't want people putting in both cases for comparison because of an undocumented feature.þ — Preceding unsigned comment added by Adam Cuerden (talkcontribs) 20 January 2015(2015-01-20) 17:20:02‎ (UTC)

CSS selectors vs #ifexist[edit]

The documentation contains the following note of interest:

For some use cases it is possible to emulate the ifexist effect with css, by using the selectors (to select links to unexisting pages) or a:not(.new) (to select links to existing pages).

Since #ifexist can be quite expensive indeed, I'd love to learn more about this. What are those use cases and how are those selectors used? Best, Cavila (MW 1.22, MySQL 5.5.37-0, Php 5.4.4-14 squeeze, SMW 1.9.2, SF 2.7) 07:57, 6 February 2015 (UTC)

In any case where you can use styling to achieve the effect you would have used #ifexist for. A missing page icon, for instance.
Also note that this is no more or less "expensive" than #ifexist (which is hardly expensive in the first place), it just simply doesn't increment the expensive parser functions count. -- 10:49, 6 February 2015 (UTC)

How to test for numeric strings?[edit]

#iferror doesn't test for numeric strings. How can that be done? --Subfader (talk) 18:56, 12 February 2015 (UTC)

Try combining it with {{#expr:}}, as in {{#iferror: {{#expr: input text }} | result if not a number | result if a number }}. There is one downside though, which is numerical operators are accepted with your numbers, for example, "1 + 1" is a number rather than a string. --KnightMiner (t/c) 19:55, 12 February 2015 (UTC)
  • I usually is #iferror: with #ifexpr: to determine if something is a number:
    • {{#iferror:{{#ifexpr:{{{someArgument| A text string }}}^0 = 1 | number | string }}| string }} → string
    • {{#iferror:{{#ifexpr:{{{someArgument| 1 + 1 }}}^0 = 1 | number | string }}| string }} → string
    • {{#iferror:{{#ifexpr:{{{someArgument| 5 }}}^0 = 1 | number | string }}| string }} → number
Good luck and happy editing! — {{U|Technical 13}} (etc) 15:08, 13 February 2015 (UTC)

Ifexist for images[edit]

Why does {{#ifexist:File:Example.png|"exists"|"doesn't exist"}} say "doesn't exist", when it definitely does? Liam987 (talk) 20:55, 20 April 2015 (UTC)

It is likely because the file is in the commons not here, and so "has been uploaded to the repository, but not to the wiki itself". Compare with {{#ifexist:Media:Example.png|"exists"|"doesn't exist"}}, which gives a different answer. --Clump (talk) 21:49, 20 April 2015 (UTC)


Is it possible to use the #expr function to obtain a remainder from a division operation? For instance, {{#expr: 8/3}} returns 2.667 (I rounded here), but the remainder is 2 (when handing eight pieces of candy to three kids, two get three each and one only gets two). I want to pull the 2. CycloneGU (talk) 18:38, 2 May 2015 (UTC)

UPDATE: I figured out another way to do it by using something like {{#expr: 8 - floor(8/3)*3}} (that's 2 by the way), but I would still like to know if it can just be pulled directly so complex formulas don't have to be performed. I did it by using a floor, then remultiplying by the division number and doing simple subtraction. A remainder function would avoid this; I mean, {{#expr 8/3 remainder}} seems so much easier and can be programmed like my example if not already present. It can then be documented. CycloneGU (talk) 20:29, 2 May 2015 (UTC)

There's a good help page on Meta, most of it created by Patrick from 2006 until 2011: m:Help:Calculation. –Be..anyone (talk) 13:45, 15 May 2015 (UTC)

Template user config files[edit]

It's funny why this statement has not been removed:

#switch</> allows an editor [to add information in one template and this information will be visible in several other templates which all have different formatting.][clarification needed][examples needed]

A switch can act as a template's configuration file ("to add info in one template... visible in several other templates"). The format of such a config file is a single switch statement in a subpage, called from the template. Because white space is ignored around the | and = , the subpage makes for easy grouping of configuration elements. Even if each line is displayed with a pipe, it is intuitive enough for editors to view or editing the set of template elements. With partial transclusion tags, the display of such a config file can render the switch statement in sections of case/result groupings, each with there own exposition and procedures.

Certainly the part about "all have different formatting" is unclear, because formatting is already provided by wikitext. "Processing" might be more accurate, but still too vague. How about

A #switch function with partial transclusion tags can effect a config file that enables any editor unfamiliar with template coding to view and edit template configuration elements. Examples include w:Template:NBA color, where any user can change the colors of a sports team, and w:Template:Val, where any user can add there own markup and link to the numeric units they want in their article.

Cpiral (talk) 20:01, 13 May 2015 (UTC)

No enwiki examples, please. The help pages here are supposed to work on any Mediawiki installation (= also outside of Wikimedia projects). They are also public domain for this job, that's why they were stolenimported from Meta eight years ago. –Be..anyone (talk) 13:52, 15 May 2015 (UTC)

#ifexist to test if user has created own page[edit]


I have tried to use #ifexist to test if the current user has created his/her user page, but {{#ifexist:Special:Mypage always returns true.

Code Result Link
{{#ifexist:User:Rbirmann|1|0}} 1 User:Rbirmann (red link, since I do not have auser page here)
{{#ifexist:Special:Mypage|1|0}} 1 Special:Mypage (always blue)
{{#ifexist:User:Tacsipacsi|1|0}} 0 User:Tacsipacsi (blue, but false since I don’t have a local user page, just on Meta)

Any ideas on how to test if the user has created his page?


--Rbirmann (talk) 18:38, 7 December 2015 (UTC)

I added another case: links to my user page are blue, however, the #ifexist returns false, because my user page comes from Meta. --Tacsipacsi (talk) 20:01, 7 December 2015 (UTC)

#titleparts replacing underscores with spaces[edit]

Can this behaviour be reversed/stopped? -- 18:32, 23 December 2015 (UTC)

Checking the existance of a section (I'm trying with #ifexist)[edit]

I need to get the information if a section with a regular name exists in a given page.

I've been trying to do that with {{#ifexist: {{FULLPAGENAME}}<-- something --> | true | false }}, where <-- something --> was changed to a lot of things like #Section Name, #Section_Name. I've seen the function does not work with interwiki links but I couldn't figure out how to solve this problem.

The idea is to check if the page has evolved every time a new section is created (wich correspond to a new level). Each section should be named "Level 1", "Level 2" and so on.

I thought about using variables to do that too, but it seems it needs more effort to get thing running right.

If I can get this information, all the rest of my work can continue quite easily.

I hope I'm not asking too much. Thanks.

Andreluciani (talk) 19:36, 26 January 2016 (UTC)

ISO 8601 ordinal day of year (YYYY-DDD) with #time[edit]

The z date formatting code gives the ordinal day of the year starting at zero for 1 January. ISO 8601 starts counting at 1 and always zero-pads its fields. This makes it awkwardly complex to get a properly formatted date: {{#time:Y-}}{{padleft:{{#expr:1+{{#time:z}}}}|3}} instead of just something simple like {{#time:Y-Z}} (and that’s without a custom date which would have to be repeated). So should we add another code? — Christoph Päper 07:47, 11 May 2016 (UTC)

#switch: on a Template {{{parameter}}}?[edit]

I am unable to get #switch: to work on a named Template parameter. What is the syntax?

| case Convention
| case Publication=
I want this included for Convention or Publication
| This is the default...

Allenhuffman (talk) 17:45, 31 August 2016 (UTC)

User error. "Case" is not part of the syntax. Allenhuffman (talk) 18:06, 31 August 2016 (UTC)

#if: both A and B[edit]

Is it even possible to use function "if" in such case: If both A and B are full/neither A nor B is empty → [something], if any of two is empty → [something else]? I somehow figured out how to use A or B but that's not my case. Thanks in advance, Arvedui89 (talk) 14:45, 15 October 2016 (UTC)

The only way is
{{#if:A|{{#if:B|<both>|<only A>}}|<not A>}}
If you have the chance to use Lua, it’s much easier and simpler:
if (A and B) then --[[ A and B ]] else --[[ one or two missing ]] end
--Tacsipacsi (talk) 22:38, 15 October 2016 (UTC)
Yep, it works for me. I was thinking through it for hours, what makes it obvious to be that simple. Thanks! Arvedui89 (talk) 18:02, 17 October 2016 (UTC)
@Tacsipacsi: Other version :
{{#if: {{#if:A|B}} | <both> | <A or B empty> }}
With this method you don't need to duplicate the code for <A or B empty>. --Zebulon84 (talk) 00:22, 18 October 2016 (UTC)

#ifeq: or?[edit]

Can #ifeq be used to compare whether or not a given parameter is equal to one string or another? Like #ifeq A or B then yes, otherwise no. --ArgonSim (talk) 04:49, 12 December 2016 (UTC)

@ArgonSim switch will probably be a better fit: {{#switch:{{{p}}}|A|B=yes|no}}. Dalba 05:06, 12 December 2016 (UTC)

div=/ (Bug ?)[edit]

  • 3 / 2 : 1.5
  • 3 div 2 : 1.5
  • 3 / -2 : -1.5
  • 3 div -2 : -1.5
  • -3 / 2 : -1.5
  • -3 div 2 : -1.5

STyx (talk) 18:28, 11 March 2017 (UTC)

Actually, they are defined to be the same. You can round the result: floor(3 / 2) = 1. --Tacsipacsi (talk) 16:59, 15 March 2017 (UTC)

#property and #statement[edit]

Please, document parser functions for Wikidata. They are hard to find, only mentioned in Wikibase/Notes/Inclusion syntax and phab:T152780. Also, they have unexpected results. If a property has a deprecated rank #property returns null. --Vriullop (talk) 10:24, 23 March 2017 (UTC)

Help with ParserFunctions[edit]

Hello. I am trying to use ParserFunctions to make a template on another wiki in which {{{1}}} is a date (for example, Jan 1, Nov 25, etc.). If a month has passed since that date, it responds "false", but if a month has not yet passed, it would say "true".
For example, today is May 2. If {{{1}}} is May 1, it would respond with "true". If {{{1}}} is April 5, it would respond with "true". If {{{1}}} is March 30, it would respond with "false". I have been trying to figure out how to accomplish this, but I still have not succeeded. Can someone please help? 2001:569:706A:8E00:AD3A:468E:E393:723B 23:24, 2 May 2017 (UTC)

See if this works:
{{  #ifexpr:  {{#time:U| {{{1}}} {{#time:Y}} }}  >  {{#time:U| now - 1 month}}  | true |  false }}
Dalba 01:24, 3 May 2017 (UTC)
Nope. It just says "Expression error: Unexpected < operator." 2001:569:706A:8E00:AD3A:468E:E393:723B 01:55, 3 May 2017 (UTC)
I think you are not calling it as a template or maybe you've not passed the first parameter. For testing, just replace {{{1}}} with your date, for example:
{{ #ifexpr: {{#time:U| April 1 {{#time:Y}} }} > {{#time:U| now - 1 month}} | true | false }}
Dalba 02:25, 3 May 2017 (UTC)

Help with #timel[edit]

When I write {{#timel: Y-m-d"T"H:i:sP}} in the danish wiki, I will get correct local time (+01 in winter, +02 in summer). But when I write this in the faroese wiki, I will get winter time (+00) also when it should be summer time (+01).
Can anybody help? Benadikt (talk) 08:16, 27 May 2017 (UTC)

Set timezone in preferences --wargo (talk) 08:41, 27 May 2017 (UTC)
No. Timezone setting should not effect the wiki content. This is because fowiki uses UTC timezone (like enwiki), which doesn’t have daylight saving time. You can ask to change it to an appropriate one (such as Europe/London) on Phabricator. Developers might ask for local consensus—changing timezone effects not only #timel parser function, but also the signature timestamps, history pages by default etc. --Tacsipacsi (talk) 09:53, 27 May 2017 (UTC)
Thank you very much, I will try to contact the administrators of fowiki first, and then Phabricator. Benadikt (talk) 10:22, 27 May 2017 (UTC)
Hello, I am administartor and Bureaucrat on the Faroese Wikipedia, we are only two administrators and there are not so many active users. I agree with Benadikt, we should of course use local Faroese time on the Faroese Wikipedia. I would be glad, if you could help us to change it. Kind regards --EileenSanda (talk) 13:34, 7 June 2017 (UTC)
Please gain local consensus – if there are few active users, of course you don’t need many votes. Just please leave a note on the village pump and give a few days for the folks to support (or oppose) it. This way your request will certainly not be declined. When the consensus is clear, I will help you post the request on Phabricator. --Tacsipacsi (talk) 18:47, 7 June 2017 (UTC)

#if test string is result of tag extension[edit]

I'm trying to use #if with the tested string being the result of a tag extension. In this case the test result always is "not empty" even when the extenstion returns an empty string, e.g.

{{#if:<mytag something='abc'/>|not empty|empty}}
{{#if:{{#tag:mytag||something='abc'}}|not empty|empty}}
{{#ifeq:<mytag something='abc'/>||not empty|empty}}

The result is always "not empty" even when <mytag ...> returns an empty string. What's the problem? -- 12:32, 15 June 2017 (UTC)

Checked the result of the tag extension using #len:

{{#len:<mytag something='abc'/>}}

The result is always "5", no matter what. But actually printing the result reveals nothing, e.g.

a<mytag something='abc'/>b{{#len:<mytag something='abc'/>}}

results in


What's going on there? -- 13:13, 15 June 2017 (UTC)

See what an expression is transformed to by the parser?[edit]

Is there some way to see what an expression containing magic words is transformed to when the magic words are parsed? I want to see what the resulting HTML code of the Chem template on Wikipedia is when I use it with some specific arguments, so I can use similar HTML code myself (because the template doesn't seem to be able to produce the notation I want to have). However, when I use template substitution and press "Show changes", the resulting code is not pure HTML but contains a lot of magic words, which makes it difficult to see what is going on. I would therefore want to convert the expression I get when I use template substitution to code in which all magic words have already been parsed out. —Kri 15:55, 25 June 2017 (UTC)

@Kri Have you tried Special:ExpandTemplates with "Show raw HTML" option checked? Dalba 16:01, 25 June 2017 (UTC)
How do I use it to show the raw HTML of the chem template, which exists on Wikipedia but not on MediaWiki? In the preview, I see Template:Chem which just indicates that the tool can't find the template. —Kri 16:13, 25 June 2017 (UTC)
@Kri Goto en:Special:ExpandTemplates, write "{{chem|4|2}}" in the input text field, check the "Show raw HTML" option, click on "OK". Dalba 16:19, 25 June 2017 (UTC)
Ah, thank you, that worked! :) —Kri 16:34, 25 June 2017 (UTC)

Use #ifexist without it appearing in whatlinkshere?[edit]

This causes some major problems with disambiguation page repair on the English Wikipedia when I've been using the function to check for the existence of pages in a Wikidata template - see [2]. Some way of using this without causing links to appear from whatlinkshere would be really useful. Thanks. Mike Peel (talk) 00:11, 16 September 2017 (UTC)

I don't think there is any way around it. Also see phab:T14019. Dalba 02:42, 16 September 2017 (UTC)
  • @Dalba: Wow, this dates back to 2007?! Thanks for the pointer, I had filed a new bug report this eve but have merged it into that one. Hopefully this can be fixed sometime in the next decade... ;-) Thanks. Mike Peel (talk) 22:50, 28 September 2017 (UTC)