Bản mẫu:Number table sorting/doc

Bách khoa toàn thư mở Wikipedia
Bước tới: menu, tìm kiếm

This template can be useful when building a sortable table in which a column contains both numbers and text. This template should be applied to every number in the column.

Currently, the template works for numbers between −10308 and 10308. Numbers outside this range will sort above or below other numbers depending on sign. See the Limitations section below.

By default the output is displayed using thousands separators. To display numbers as entered, use |format = no.

The template generates a hidden "sort key" in the HTML markup which forces the JavaScript sorting algorithm to sort the column alphabetically.

Mục đích[sửa mã nguồn]

There are at two cases where this template is useful:

  1. When numbers are followed by some text
  2. When numbers are preceded by some text other than a currency symbol.

Các thông số[sửa mã nguồn]

The template has only one required parameter: a real number. These examples use the name of the redirect, {{nts}}, for brevity.

Các thông số tùy chọn
  • prefix: To display some text before the number, use |prefix = some prefix
    {{nts|123456789.00123|prefix=approx. }}approx. 12.345.678.900.123
  • format: For unformatted output, use |format = no
    {{nts|123456789.00123}}12.345.678.900.123
    {{nts|123456789.00123|format=no}}12345678900123
  • debug: To display the sort key, use |debug = yes.
    {{nts|123456789.00123|debug=yes}}7013123456789001230♠12.345.678.900.123
    {{nts|-123456789.00123|debug=yes}}2986876543210998770♠−12.345.678.900.123

Apart from the added thousands separators the numbers are formatted as supplied (scientific notation or not, leading and trailing zeros, and a zero before the decimal point or not). This formatting does not affect the sorted order except for numbers not satisfying the limitations mentioned below.

Đây là các Dữ liệu về bản mẫu này. Nó được sử dụng bởi Trình soạn thảo trực quan.

Number table sorting

Tham số bản mẫu

Tham số Miêu tả Kiểu Trạng thái
Number 1

Your number

Mặc định
trống
Ví dụ
trống
Giá trị tự động
trống
Số bắt buộc
Format output? format

If you do not wish the output to be formatted (i.e. separated by thousand separators), please put "no" in this field. (Without quotation marks.)

Mặc định
trống
Ví dụ
trống
Giá trị tự động
trống
Chuỗi tùy chọn
Debug debug

If set to "yes", forces output to include debug data

Mặc định
trống
Ví dụ
trống
Giá trị tự động
trống
Chuỗi tùy chọn
Prefix prefix

The prefix to be displayed before the number. E.g. "Appox." or "$"

Mặc định
trống
Ví dụ
trống
Giá trị tự động
trống
Chuỗi tùy chọn

Sắp xếp chủ chốt[sửa mã nguồn]

The sort key is a nineteen-digit number. For numbers within range the first four digits are determined by the number's sign and order of magnitude and the next fifteen digits are determined by the number's sign and significand.

Số trong phạm vi
  • For numbers between 10−308 and 10308 the first four digits are calculated by adding 7000 to the order of magnitude and the next fifteen digits are calculated by multiplying the significand by 1014.
  • For numbers between −10−308 and −10308 the first four digits are calculated by subtracting the order of magnitude from 2999 and the next fifteen digits are calculated by subtracting the significand from 10 multiplying the difference by 1014.
  • The sort key for 0 is 5000000000000000000.
Số ra khỏi phạm vi
  • Numbers larger than 10308 are assigned the sort key 9000000000000000000.
  • Numbers smaller than −10308 are assigned the sort key 1000000000000000000.
  • Numbers between 10−308 and 0 or between 0 and −10−308 are assigned the sort key 5000000000000000000.

Hạn chế[sửa mã nguồn]

  • Any subset of numbers larger than 10308 are sorted together.
  • Any subset of numbers smaller than −10308 are sorted together.
  • Any subset of numbers between 10−308 and −10−308 are sorted together.
  • If a non-numeric value is given as the first unnamed parameter the results are undefined.
  • The hyphen minus sign is converted into a true minus sign; note, though, that this means no more than 12 significant figures are possible.
  • A prefix (using the prefix parameter) does not affect the sort order.

Các ví dụ[sửa mã nguồn]

{{nts|123456789.00123}}7013123456789001230♠12.345.678.900.123

For text which follows a number, {{nts|123,456}} as of 2012 displays 123,456 as of 2012 with a numerical sort key of 123456. This forces numerical sorting in the cell using this value instead of the default alphabetical sorting.

Below are more examples, some of which illustrate the limitations listed above.

Mã wiki Sắp xếp chủ chốt và số error spillover
{{nts|debug=yes}}
{{nts||debug=yes}}
{{nts|between 2 and 3|debug=yes}} Lỗi: between 2 and 3 Đây là một số không hợp lệ. Xin vui lòng tham khảo tài liệu tại {{number table sorting}} cho nhập vào chính xác.
{{nts|between 2 and 3|debug=no}} Lỗi: between 2 and 3 Đây là một số không hợp lệ. Xin vui lòng tham khảo tài liệu tại {{number table sorting}} cho nhập vào chính xác.
{{nts|10|prefix=approx.{{sp}}|debug=yes}} 7001100000000000000♠approx. 10
{{nts|-5|debug=yes}} 2999500000000000000♠−500.000.000.000
{{nts|-4|debug=yes}} 2999600000000000000♠−400.000.000.000
{{nts|-73|debug=yes}} 2998270000000000000♠−730.000.000.000
{{nts|-67|debug=yes}} 2998330000000000000♠−670.000.000.000
{{nts|-20345678901234567.12345678|debug=yes}} 2975796543210987654♠−2,0345678901235×10^24
{{nts|123.456e3|debug=yes}} 7008123456000000000♠1,23456×10^8
{{nts|123.456e2|debug=yes}} 7007123456000000000♠1,23456×10^7
{{nts|20345678901234567.12345678|debug=yes}} 7024203456789012345♠2.034.567.890.123.456.712.345.678
{{nts|100345678901234567.12345678|debug=yes}} 7025100345678901234♠10.034.567.890.123.456.712.345.678
{{nts|1234567890123456.12345678|debug=yes}} 7023123456789012345♠123.456.789.012.345.612.345.678
{{nts|234567890123456.12345678|debug=yes}} 7022234567890123456♠23.456.789.012.345.612.345.678
{{nts|34567890123456.12345678|debug=yes}} 7021345678901234561♠3.456.789.012.345.612.345.678
{{nts|4567890123456.12345678|debug=yes}} 7020456789012345612♠456.789.012.345.612.345.678
{{nts|567890123456.12345678|debug=yes}} 7019567890123456123♠56.789.012.345.612.345.678
{{nts|67890123456.12345678|debug=yes}} 7018678901234561234♠6.789.012.345.612.345.678
{{nts|7890123456.12345678|debug=yes}} 7017789012345612345♠789.012.345.612.345.678
{{nts|890123456.12345678|debug=yes}} 7016890123456123456♠89.012.345.612.345.678
{{nts|90123456.12345678|debug=yes}} 7015901234561234567♠9.012.345.612.345.678
{{nts|0123456.12345678|debug=yes}} 7013123456123456780♠012.345.612.345.678
{{nts|123456.12345678|debug=yes}} 7013123456123456780♠12.345.612.345.678
{{nts|23456.12345678|debug=yes}} 7012234561234567800♠2.345.612.345.678
{{nts|3456.12345678|debug=yes}} 7011345612345678000♠345.612.345.678
{{nts|456.12345678|debug=yes}} 7010456123456780000♠45.612.345.678
{{nts|56.12345678|debug=yes}} 7009561234567800000♠5.612.345.678
{{nts|6.12345678|debug=yes}} 7008612345678000000♠612.345.678
{{nts|.12345678|debug=yes}} 7007123456780000000♠12.345.678
{{nts|0.12345678|debug=yes}} 7007123456780000000♠012.345.678
{{nts|0.02345678|debug=yes}} 7006234567800000000♠002.345.678
{{nts|0.00345678|debug=yes}} 7005345678000000000♠000.345.678
{{nts|0.00045678|debug=yes}} 7004456780000000000♠000.045.678
{{nts|0.00005678|debug=yes}} 7003567800000000000♠000.005.678
{{nts|0.00000678|debug=yes}} 7002678000000000000♠000.000.678
{{nts|0.00000078|debug=yes}} 7001780000000000000♠000.000.078
{{nts|0.00000008|debug=yes}} 7000800000000000000♠000.000.008
{{nts|.00000008|debug=yes}} 7000800000000000000♠00.000.008
{{nts|0|debug=yes}} 5000000000000000000♠0

Xem thêm[sửa mã nguồn]

  • {{Ntsh}} - same as this template, but does not display (hides) the number
  • {{val}} - displays numbers and quantities with various formatting options
  • {{Convert}} - has a sortable option
  • {{Dts}} - for sorting dates
  • {{Sort}}
  • {{Hidden sort key}}