Commit 78992439 authored by Rob Pike's avatar Rob Pike

fmt: improve documentation for width and precision

Fixes #7048.

LGTM=dominik.honnef
R=golang-codereviews, dominik.honnef
CC=golang-codereviews
https://golang.org/cl/74280044
parent 1f4d2e79
...@@ -50,23 +50,39 @@ ...@@ -50,23 +50,39 @@
There is no 'u' flag. Integers are printed unsigned if they have unsigned type. There is no 'u' flag. Integers are printed unsigned if they have unsigned type.
Similarly, there is no need to specify the size of the operand (int8, int64). Similarly, there is no need to specify the size of the operand (int8, int64).
The width and precision control formatting and are in units of Unicode Width is specified by an optional decimal number immediately following the verb.
code points. (This differs from C's printf where the units are numbers If absent, the width is whatever is necessary to represent the value.
Precision is specified after the (optional) width by a period followed by a
decimal number. If no period is present, a default precision is used.
A period with no following number specifies a precision of zero.
Examples:
%f: default width, default precision
%9f width 9, default precision
%.2f default width, precision 2
%9.2f width 9, precision 2
%9.f width 9, precision 0
Width and precision are measured in units of Unicode code points.
(This differs from C's printf where the units are numbers
of bytes.) Either or both of the flags may be replaced with the of bytes.) Either or both of the flags may be replaced with the
character '*', causing their values to be obtained from the next character '*', causing their values to be obtained from the next
operand, which must be of type int. operand, which must be of type int.
For numeric values, width sets the minimum width of the field and For most values, width is the minimum number of characters to output,
padding the formatted form with spaces if necessary.
For strings, precision is the maximum number of characters to output,
truncating if necessary.
For floating-point values, width sets the minimum width of the field and
precision sets the number of places after the decimal, if appropriate, precision sets the number of places after the decimal, if appropriate,
except that for %g/%G it sets the total number of digits. For example, except that for %g/%G it sets the total number of digits. For example,
given 123.45 the format %6.2f prints 123.45 while %.4g prints 123.5. given 123.45 the format %6.2f prints 123.45 while %.4g prints 123.5.
The default precision for %e and %f is 6; for %g it is the smallest The default precision for %e and %f is 6; for %g it is the smallest
number of digits necessary to identify the value uniquely. number of digits necessary to identify the value uniquely.
For most values, width is the minimum number of characters to output, For complex numbers, the width and precision apply to the two
padding the formatted form with spaces if necessary. components independently and the result is parenthsized, so %f applied
For strings, precision is the maximum number of characters to output, to 1.2+3.4i produces (1.200000+3.400000i).
truncating if necessary.
Other flags: Other flags:
+ always print a sign for numeric values; + always print a sign for numeric values;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment