Template:Convert
- This article uses content from the Wikipedia article on Template:Convert/doc (edition) under the terms of the CC-by-SA 3.0 license.
|  | The Template:Convert and most of its high-risk subtemplates have been protected so that only admins can edit them. Discuss proposed changes on the Convert talk-page. | 
Contents
Usage
This template shows measurement quantities as primary and converted secondary units (or ranges), with optional rounding, wikilinks, abbreviation, or US spellings, and various separators including: parentheses "( )", slash, "or", hyphens, comma, "to" or dashes. Styles include: distance "32 metres (105 ft)" and "32 metres or 105 ft"; temperature "Template:Convert/°C" or "Template:Convert/°C"; weight "Template:Convert/kg" or "Template:Convert/to"; etc. For units see: Convert/list of units.
| Options include: | lk=in,abbr=on,abbr=none,sp=us,adj=on,adj=mid,disp=x,disp=tableandsortable=on(explained below). By default, output is rounded to match the precision of input; alternatives include:sigfig=3or using the end parameter, such as "|1" to show tenths or "|-2" to show full 100's, etc. | 
Single value:
{{convert|value|in_unit|out_unit|round_to|...}}
Range of 2 values, or set of 3 or 4 (see below for list of range options):
{{convert|val1|range|val2 |in_unit|out_unit|round_to|...}}
{{convert/3 |val1|range|val2|words|val3|in_unit|out_unit|round_to|...}}
{{convert/4 |val1|words|val2|words|val3|words|val4|in_unit|out_unit|...}}
- Numbers must be entered in unformatted form (without commas). Values output by the template will be displayed formatted and with a true minus sign where appropriate. To specify with commas, re-code a number as {{formatnum:9,000,500|R}} (becomes 9000500).
- Optional parameters, in examples below, allow abbreviated units (abbr=on), or US spellings (sp=us for meter), or slash separation (disp=s), or hyphenation (adj=on), etc.
- For this template many levels of substitution are possible, hence doing this fully, step by step, is cumbersome. Use Special:ExpandTemplates instead.
-  The template has no in-built capacity for dimensional analysis.  It is therefore up to the user to ensure that most input and output units are compatible.  Do not, for example, attempt to convert barrels to tonnes (but see {{bbl to t}}).  Also beware of units with similar names; the code oz, for example, is for the avoirdupois ounce (a unit of mass), do not use this if you want fluid ounces.
- An attempt to convert a unit to itself (e.g. km to km), will result in a template loop.
- The range functionality is not fully implemented for all units, so experimentation may be required.
- This documentation page tends to lag behind in terms of what the template can do. For details see the talk page and its archives.
Examples
Single value
| Input | Displays as | 
| {{convert|3.21|kg|lb}} | Template:Convert/kg | 
| {{convert|3.21|kg|lb|0}} | Template:Convert/kg | 
| {{convert|10|kg |lb |disp=or}} | Template:Convert/kg | 
| {{convert|6|ft|5|in|m}} | 6 feet Template:Convert/and/frn2 (1.96 m) | 
| {{convert|10|mi}} | 10 miles (16 km) | 
| {{convert|100|mpgus}} | Template:Convert/mpgus | 
| {{convert|120|km/h}} | Template:Convert/km/h | 
| {{convert|18|°C|°F}} | Template:Convert/°C | 
| {{convert|1250|sqft|m2|lk=in|sigfig=2}} | 1,250 square feet (120 m2) Note 'lk=in' links only the input unit. This example is for illustration only, common units of measurement should not be linked. See: wp:overlink. | 
| {{convert|20.5|m3|cuyd|lk=out|abbr=on}} | Template:Convert/m3 Note 'lk=out' links only the output unit, cu yd. | 
| {{convert|641|acre|km2 sqmi|lk=on}} | 641 acres (2.59 km2; 1.002 sq mi) Note 'lk=on' links all units. Per guidelines, common units should not be linked. See: wp:overlink. | 
| {{convert|641|acre|km2 sqmi|2|lk=on}} | 641 acres (2.59 km2; 1.00 sq mi) Although 640 acres equals 1 square mile; 641 acres rounded to two decimal places equals 1.00 sq mi. | 
Range of 2 values
- Note: not yet operational for all units
| Input | Displays as | 
| {{convert|60|and|170|kg|lb}} | Template:Convert/and | 
| {{convert|60|to|170|kg|lb}} | Template:Convert/to | 
| {{convert|60|to(-)|170|kg|lb}} | Template:Convert/to(-) | 
| {{convert|60|-|170|kg|lb}} | Template:Convert/kg | 
| {{convert|41|to|50|F|C}} | Template:Convert/to | 
| {{convert|41|-|50 |F|K}} | Template:Convert/F | 
| {{convert|60|x|120|m|ft}} | Template:Convert/x | 
| {{convert|60|+/-|10|m|ft}} | Template:Convert/+/- | 
| {{convert|19|to|27|L|USgal}} | Template:Convert/to | 
| {{convert|5|to|7|L|USgal|abbr=mos}} | Template:Convert/to | 
| {{convert|4|-|9|L|USgal|abbr=none}} | Template:Convert/L | 
| {{convert|30|-|40|mpg}} | Template:Convert/mpg | 
| {{convert|7|-|9|L100km}} | Template:Convert/L100km | 
The following conversions are currently not available as a range of values:
- Some imperial and US gallon-based units
- Other fuel-consumption units, except "mpg" or "L100km" shown above.
- Large scale units (e3, e6, e9)
- Combination-based units (ft&in, st&lb, lb&oz) due to complexity of the conversion.
Range/set of 3 or 4 values
- Note: not yet operational for all units
| Input | Displays as | 
| {{convert/3 |2|x|4|x|6|m|ft}} | 2×4×6 metres (6.6×13×20 ft) | 
| {{convert/3 |60|-|70|-|80|kg|lb}} | 60–70–80 Template:Convert/kg (Template:Convert/kg–Template:Convert/kg–Template:Convert/kg) | 
| {{convert/4 |60|-|70|-|80|-|90|kg|lb}} | Template:Convert/4 | 
| {{convert/3 |60|to|80|or|85|m|ft}} | 60 to 80 or 85 metres (200 to 260 or 279 ft) | 
| {{convert/3 |11|by|15|rarely|16|ft|m}} | 11 by 15 rarely 16 feet (3.4 by 4.6 rarely 4.9 m) | 
| {{convert/3 |41|to|50|to|60|F|C}} | 41 to 50 to 60 Template:Convert/F (Template:Convert/F to Template:Convert/F to Template:Convert/F) | 
| {{convert/4 |2|to|12|, in summer|25|to|36|C|F}} | Template:Convert/4 | 
| {{convert/3 |41|-|50|almost|51|F|K}} | 41–50 almost 51 Template:Convert/F (Template:Convert/F–Template:Convert/F almost Template:Convert/F) | 
For {{convert/4}}, the separator words can be any text. For {{convert/3}}, the first separator word must be x, and, or, to, -, or by.
Parameters
| Parameters | |
|---|---|
| Use US spelling | attach |sp=us | 
| Make units wikilinked | attach |lk=onto link all units                               (default: lk=off)attach |lk=into link only the input unitsattach |lk=outto link only the output units(The manual of style suggests that you should not link common units of measurement). | 
| Use the adjective form, or insert mid-text words | attach |adj=on(e.g. "The 190-foot (58 m) bridge" as opposed to "The 190 feet..."). This produces the adjective form—the unit name in the singular with a hyphen (according to the Manual of Style).attach |adj=mid(e.g. "The 190-foot bridge (58 m)" as: |adj=mid|bridge, or "The 190-foot-long bridge (58 m)" as: |adj=mid|-long bridge)Any rounding-parameter should follow the mid-text: "text|0". | 
| Abbreviate units, or not | attach |abbr=onto show unit symbols          (default: abbr=off)attach |abbr=noneto show all unit names in full wordsattach |abbr=into abbreviate input unitsattach |abbr=outto abbreviate output unitsattach |abbr=valuesto suppress unit names & show only values. So, {{convert|6|mi|abbr=values}} gives: Template:Convert/LoffAvaluesDbSoff. | 
| Change "( )" to display other separators | attach |disp=commato put comma, not brackets/parenthesesattach |disp=orto put "or" between unitsattach |disp=s(or|disp=/) for slash (e.g. 190 foot/58 metre). The default value is:  disp=b for brackets/parentheses. | 
| Change "( )" to customized separators | attach |disp=x| (begin | end)to show "xx (begin yy end)" See example 1attach |disp=x|;to show "xx; yy" See example 2attach |disp=x| (same as |)to show "xx (same as yy)". See example 3Example 1: {{convert|9|km|mi|disp=x| [|]}}→9 kilometres [5.6 mi] (note space before [|) Example 2: {{convert|9|km|mi|disp=x|;}}→9 kilometres;5.6 mi Example 3: {{convert|10|km|mi|disp=x| (about |)}}→10 kilometres (about 6.2 mi) (note spaces used within the code). | 
| Display output only | attach |disp=output onlyto show result number & unitattach |disp=output number onlyto show just numberNote when using "disp=output only" then the unit name can still be shown as full words by abbr=none, or linked by lk=on. | 
| Display units inverted as reverse order | attach |disp=flipto reverse the order & show output unit firstSo, {{convert|6|km|disp=flip}} shows "3.2 mi (6 kilometres)". To get symbol "km" use abbr=in, to abbreviate the input unit. | 
| Display unit name (only) | attach |disp=unitto show the unit name for a symbolThe unit name will be plural when the amount is not 1, or hyphenated when adj=on. So, {{convert|2|cuyd|disp=unit}} shows "cubic yards" plural. | 
| Display amounts as table cells | attach |disp=table (or |disp=tablecen) Note: For use in tables, the template must start on a new line after a pipe.  Only the number will be displayed unless you set |abbr=on,|lk=on,|lk=inor|lk=out. Example: here | 
| Round to a specified number of significant figures | attach |sigfig={some non-negative integer}. In the case of temperatures Celsius or Fahrenheit this refers to the difference with the absolute-zero temperature. For example, at room temperature two significant digits means rounded to tens of degrees. | 
| Round by 5 | attach |disp=5 to round the output amount to the nearest 5 units. Not supported for all options. | 
| Let Convert decide the unit to convert to | skip the precision parameter (the 3rd or 4th unnamed parameter) e.g. {{convert|100|km|kn}}gives 100 kilometres (Template:Convert/kn) and{{convert|100|km}}gives 100 kilometres (62 mi). | 
| Display input value with a fraction | {{convert|3/8|in|mm|3|abbr=on}}→ Template:Convert/in or {{convert|11+1/4|in|cm|2|abbr=on}}→Template:Convert/in For negative amounts, use 2 minus signs: -11-1/4. | 
| Generate a hidden sort key for use with a sortable table | attach |sortable=onto generate a hidden sort key (in the form of<span style="display:none">00000005</span>) so that sortable tables will sort correctly. This takes the first numeric value and left pads it with zeros to 16 places. It ignores any additional values, ie, if you use6|ft|2|inas the value, it will only use the 6 for the sort key. This will cause numeric values to sort in numeric order, ie: 5, 10, 15 instead of 10, 15, 5. | 
Parameters still under construction
| Parameters still under construction. May not work in all situations | |
|---|---|
| Round by 5 | attach |disp=5 to round output to nearest 5 units. Might not work when linking unit names. | 
| disp=tablecen | Similar to disp=table except that the values with be centered within the column. See the tables at La Nouvelle branch, BM-21 Grad for in use examples. | 
| disp=comma | Similar to disp=s except the two values will be separated by a comma, for situations where the first value is already within parentheses. See the Geography tables on Labrador for an example. | 
| abbr=in | Abbreviates only the input unit. | 
| abbr=out | Abbreviates only the output unit. | 
| abbr=comma | Abbreviates (removes) commas. This is a limited, temporary option, until comma=off can be implemented. For ranges, using abbr=comma conflicts with internal options, so instead, append "nocomma" to a range-word: tonocomma, bynocomma, andnocomma, -nocomma & xnocomma. | 
| abbr=mos | For ranges, abbreviates with the input unit repeated, twice. Not to be confused with the specifications at MOS:NUM#Conventions. | 
| disp=br | For using [brackets] instead of (parentheses), this would be best used when measurements are written within an existing set of (parentheses).  It is grammatically correct and avoids double parentheses: )).  Must use |abbr=on to force all units abbreviated, otherwise units are not abbreviated.  Example: 55 miles [89 kilometres].  SEE attach |disp=x| above as another way of fully implementing brackets []. | 
Rounding
Convert supports four types of rounding:
- Rounding to a given precision
- Specify the desired precision with the fourth unnamed parameter (or third unnamed parameter if the "convert to" parameter is omitted; or fifth unnamed parameter if a range is specified; or fourth unnamed parameter again if a range is specified and the "convert to" parameter is omitted; needs to be replaced with a "precision" named parameter). The conversion is rounded off to the nearest power of Template:Frac this number. For instance, if the result is 8621 and the round number is '-2', the result will be 8600. If the result is '234.0283043' and the round number is '0', the result will be 234.
- Rounding to a given number of significant figures
- Specify the desired number of significant figures using <code>|sigfig={some non-negative integer} as noted above.
- Combine both of the above
- If both the desired precision and the desired number of significant figures are specified, the conversion will be rounded to the least precise of these.
- Default rounding
- If neither the desired precision nor the desired number of significant figures are specified, the conversion will be rounded either to a comparable precision as the input value (the number of digits after the decimal point—or the negative of the number of non-significant zeroes before the point—is increased by one if the conversion is a multiplication by a number between 0.02 and 0.2, remains the same if the factor is between 0.2 and 2, is decreased by 1 if it is between 2 and 20, and so on) or to two significant figures, whichever is the most precise. An exception to this is temperature wherein the conversion will be rounded either to precision comparable to that of the input value or to that which would give three significant figures when expressed in kelvins, whichever is the most precise.
Units supported
The table below lists units supported by this template. It is divided up according to the quantity being measured. Not all supported units are listed here; there are links to complete lists for each quantity.
The codes listed in the code column (column 3) are accepted as input by the template. These can be used as the second or third unnamed parameter. For some units there exist alternative codes. These are listed in brackets and have been incorporated to make the code more flexible for editors, e.g. °F or F may be entered.
The codes listed in the combinations column (column 7) can be used to produce multiple conversions. They can only be used as the third unnamed parameter, e.g. {{convert|55|nmi|km mi}} produces "Template:Convert/nmi".
Examples
- Monitor quality or look at examples at {{Convert/check}}.
See also
- {{Convinfobox}} for use in infoboxes
- {{Bbl to t}} for converting barrel of oil to tonnes
- {{CwtQtrLb to kg}} for converting long hundred weights, quarters and pounds into kilograms
- {{Decdeg}} for converting degrees, minutes and seconds to decimal degrees
- {{HMS2Deg}} for converting hour angles, given in hours, minutes and seconds, to decimal degrees
- {{Height}} for converting and displaying a person's height
- {{Miles-chains}} for converting miles and chains to kilometres linking "chains"
- {{Pop density}} for converting a population and area to a density
- {{Inflation}} for calculating inflation of Consumer Price Index related prices
- {{Metricate}}
- {{RailGauge}} for converting rail (track) gauges
- {{Convert/scale}} with custom formula for converting any linearly related units
- Bug 235: Auto unit conversion
| The above documentation is transcluded from Template:Convert/doc. (edit | history) Editors can experiment in this template's sandbox (create | mirror) and testcases (create) pages. Please add categories to the /doc subpage. Subpages of this template. | 
 Template documentation
 Template documentation
