2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
GDScript format strings
|
|
|
|
=======================
|
|
|
|
|
|
|
|
GDScript offers a feature called *format strings*, which allows reusing text
|
|
|
|
templates to succinctly create different but similar strings.
|
|
|
|
|
|
|
|
Format strings are just like normal strings, except they contain certain
|
|
|
|
placeholder character-sequences. These placeholders can then easily be replaced
|
|
|
|
by parameters handed to the format string.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
As an example, with `%s` as a placeholder, the format string `"Hello %s, how
|
|
|
|
are you?"` can easily be changed to `"Hello World, how are you?"`. Notice
|
2022-03-18 17:46:08 +01:00
|
|
|
the placeholder is in the middle of the string; modifying it without format
|
|
|
|
strings could be cumbersome.
|
|
|
|
|
|
|
|
|
|
|
|
Usage in GDScript
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Examine this concrete GDScript example:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
# Define a format string with placeholder '%s'
|
|
|
|
var format_string = "We're waiting for %s."
|
|
|
|
|
|
|
|
# Using the '%' operator, the placeholder is replaced with the desired value
|
2024-03-16 20:56:52 +01:00
|
|
|
var actual_string = format_string % "Pandemonium"
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
print(actual_string)
|
2024-03-16 20:56:52 +01:00
|
|
|
# Output: "We're waiting for Pandemonium."
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Placeholders always start with a `%`, but the next character or characters,
|
2022-03-18 17:46:08 +01:00
|
|
|
the *format specifier*, determines how the given value is converted to a
|
|
|
|
string.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `%s` seen in the example above is the simplest placeholder and works for
|
2022-03-18 17:46:08 +01:00
|
|
|
most use cases: it converts the value by the same method by which an implicit
|
2023-01-12 19:43:03 +01:00
|
|
|
String conversion or `str()` would convert it. Strings remain unchanged,
|
|
|
|
Booleans turn into either `"True"` or `"False"`, an integral or real number
|
2022-03-18 17:46:08 +01:00
|
|
|
becomes a decimal, other types usually return their data in a human-readable
|
|
|
|
string.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
There is also another way to format text in GDScript, namely the `String.format()`
|
2022-03-18 17:46:08 +01:00
|
|
|
method. It replaces all occurrences of a key in the string with the corresponding
|
|
|
|
value. The method can handle arrays or dictionaries for the key/value pairs.
|
|
|
|
|
|
|
|
Arrays can be used as key, index, or mixed style (see below examples). Order only
|
|
|
|
matters when the index or mixed style of Array is used.
|
|
|
|
|
|
|
|
A quick example in GDScript:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
# Define a format string
|
|
|
|
var format_string = "We're waiting for {str}"
|
|
|
|
|
|
|
|
# Using the 'format' method, replace the 'str' placeholder
|
2024-03-16 20:56:52 +01:00
|
|
|
var actual_string = format_string.format({"str": "Pandemonium"})
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
print(actual_string)
|
2024-03-16 20:56:52 +01:00
|
|
|
# Output: "We're waiting for Pandemonium"
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:57:31 +01:00
|
|
|
There are other `format specifiers`, but they are only applicable when using
|
2023-01-12 19:43:03 +01:00
|
|
|
the `%` operator.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
Multiple placeholders
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
Format strings may contain multiple placeholders. In such a case, the values
|
|
|
|
are handed in the form of an array, one value per placeholder (unless using a
|
2023-01-12 20:57:31 +01:00
|
|
|
format specifier with `*`, see `dynamic padding`):
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
var format_string = "%s was reluctant to learn %s, but now he enjoys it."
|
|
|
|
var actual_string = format_string % ["Estragon", "GDScript"]
|
|
|
|
|
|
|
|
print(actual_string)
|
|
|
|
# Output: "Estragon was reluctant to learn GDScript, but now he enjoys it."
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Note the values are inserted in order. Remember all placeholders must be
|
|
|
|
replaced at once, so there must be an appropriate number of values.
|
|
|
|
|
|
|
|
|
|
|
|
Format specifiers
|
|
|
|
-----------------
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
There are format specifiers other than `s` that can be used in placeholders.
|
2022-03-18 17:46:08 +01:00
|
|
|
They consist of one or more characters. Some of them work by themselves like
|
2023-01-12 19:43:03 +01:00
|
|
|
`s`, some appear before other characters, some only work with certain
|
2022-03-18 17:46:08 +01:00
|
|
|
values or characters.
|
|
|
|
|
|
|
|
|
|
|
|
Placeholder types
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
One and only one of these must always appear as the last character in a format
|
2023-01-12 19:43:03 +01:00
|
|
|
specifier. Apart from `s`, these require certain types of parameters.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `s` | **Simple** conversion to String by the same method as implicit |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | String conversion. |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `c` | A single **Unicode character**. Expects an unsigned 8-bit integer |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | (0-255) for a code point or a single-character string. |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `d` | A **decimal integral** number. Expects an integral or real number |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | (will be floored). |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `o` | An **octal integral** number. Expects an integral or real number |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | (will be floored). |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `x` | A **hexadecimal integral** number with **lower-case** letters. |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | Expects an integral or real number (will be floored). |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `X` | A **hexadecimal integral** number with **upper-case** letters. |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | Expects an integral or real number (will be floored). |
|
|
|
|
+-------+---------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `f` | A **decimal real** number. Expects an integral or real number. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-------+---------------------------------------------------------------------+
|
|
|
|
|
|
|
|
|
|
|
|
Placeholder modifiers
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
These characters appear before the above. Some of them work only under certain
|
|
|
|
conditions.
|
|
|
|
|
|
|
|
+---------+-------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `+` | In number specifiers, **show + sign** if positive. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+---------+-------------------------------------------------------------------+
|
|
|
|
| Integer | Set **padding**. Padded with spaces or with zeroes if integer |
|
2023-01-12 19:43:03 +01:00
|
|
|
| | starts with `0` in an integer or real number placeholder. |
|
|
|
|
| | The leading `0` is ignored if `-` is present. |
|
|
|
|
| | When used after `.`, see `.`. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+---------+-------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `.` | Before `f`, set **precision** to 0 decimal places. Can be |
|
2022-03-18 17:46:08 +01:00
|
|
|
| | followed up with numbers to change. Padded with zeroes. |
|
|
|
|
+---------+-------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `-` | **Pad to the right** rather than the left. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+---------+-------------------------------------------------------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `*` | **Dynamic padding**, expect additional integral parameter to set |
|
2023-01-12 20:57:31 +01:00
|
|
|
| | padding or precision after `.`, see `dynamic padding`. |
|
2022-03-18 17:46:08 +01:00
|
|
|
+---------+-------------------------------------------------------------------+
|
|
|
|
|
|
|
|
|
|
|
|
Padding
|
|
|
|
-------
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `.` (*dot*), `*` (*asterisk*), `-` (*minus sign*) and digit
|
|
|
|
(`0`-`9`) characters are used for padding. This allows printing several
|
2022-03-18 17:46:08 +01:00
|
|
|
values aligned vertically as if in a column, provided a fixed-width font is
|
|
|
|
used.
|
|
|
|
|
|
|
|
To pad a string to a minimum length, add an integer to the specifier:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
print("%10d" % 12345)
|
|
|
|
# output: " 12345"
|
|
|
|
# 5 leading spaces for a total length of 10
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
If the integer starts with `0`, integral values are padded with zeroes
|
2022-03-18 17:46:08 +01:00
|
|
|
instead of white space:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
print("%010d" % 12345)
|
|
|
|
# output: "0000012345"
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Precision can be specified for real numbers by adding a `.` (*dot*) with an
|
|
|
|
integer following it. With no integer after `.`, a precision of 0 is used,
|
2022-03-18 17:46:08 +01:00
|
|
|
rounding to integral value. The integer to use for padding must appear before
|
|
|
|
the dot.
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
# Pad to minimum length of 10, round to 3 decimal places
|
|
|
|
print("%10.3f" % 10000.5555)
|
|
|
|
# Output: " 10000.556"
|
|
|
|
# 1 leading space
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `-` character will cause padding to the right rather than the left,
|
2022-03-18 17:46:08 +01:00
|
|
|
useful for right text alignment:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
print("%-10d" % 12345678)
|
|
|
|
# Output: "12345678 "
|
|
|
|
# 2 trailing spaces
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
Dynamic padding
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
By using the `*` (*asterisk*) character, the padding or precision can be set
|
2022-03-18 17:46:08 +01:00
|
|
|
without modifying the format string. It is used in place of an integer in the
|
|
|
|
format specifier. The values for padding and precision are then passed when
|
|
|
|
formatting:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
var format_string = "%*.*f"
|
|
|
|
# Pad to length of 7, round to 3 decimal places:
|
|
|
|
print(format_string % [7, 3, 8.8888])
|
|
|
|
# Output: " 8.889"
|
|
|
|
# 2 leading spaces
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
It is still possible to pad with zeroes in integer placeholders by adding `0`
|
|
|
|
before `*`:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
print("%0*d" % [2, 3])
|
|
|
|
# Output: "03"
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
Escape sequence
|
|
|
|
---------------
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
To insert a literal `%` character into a format string, it must be escaped to
|
2022-03-18 17:46:08 +01:00
|
|
|
avoid reading it as a placeholder. This is done by doubling the character:
|
|
|
|
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
var health = 56
|
|
|
|
print("Remaining health: %d%%" % health)
|
|
|
|
# Output: "Remaining health: 56%"
|
2023-01-12 22:32:46 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
Format method examples
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
The following are some examples of how to use the various invocations of the
|
2023-01-12 19:43:03 +01:00
|
|
|
`String.format` method.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
|
|
|
| **Type** | **Style** | **Example** | **Result** |
|
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Dictionary | key | `"Hi, {name} v{version}!".format({"name":"Godette", "version":"3.0"})` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Dictionary | index | `"Hi, {0} v{1}!".format({"0":"Godette", "1":"3.0"})` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Dictionary | mix | `"Hi, {0} v{version}!".format({"0":"Godette", "version":"3.0"})` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Array | key | `"Hi, {name} v{version}!".format([["version","3.0"], ["name","Godette"]])` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Array | index | `"Hi, {0} v{1}!".format(["Godette","3.0"])` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Array | mix | `"Hi, {name} v{0}!".format([3.0, ["name","Godette"]])` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Array | no index | `"Hi, {} v{}!".format(["Godette", 3.0], "{}")` | Hi, Godette v3.0! |
|
2022-03-18 17:46:08 +01:00
|
|
|
+------------+-----------+------------------------------------------------------------------------------+-------------------+
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Placeholders can also be customized when using `String.format`, here's some
|
2022-03-18 17:46:08 +01:00
|
|
|
examples of that functionality.
|
|
|
|
|
|
|
|
|
|
|
|
+-----------------+------------------------------------------------------+------------------+
|
|
|
|
| **Type** | **Example** | **Result** |
|
|
|
|
+-----------------+------------------------------------------------------+------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Infix (default) | `"Hi, {0} v{1}".format(["Godette", "3.0"], "{_}")` | Hi, Godette v3.0 |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-----------------+------------------------------------------------------+------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Postfix | `"Hi, 0% v1%".format(["Godette", "3.0"], "_%")` | Hi, Godette v3.0 |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-----------------+------------------------------------------------------+------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| Prefix | `"Hi, %0 v%1".format(["Godette", "3.0"], "%_")` | Hi, Godette v3.0 |
|
2022-03-18 17:46:08 +01:00
|
|
|
+-----------------+------------------------------------------------------+------------------+
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Combining both the `String.format` method and the `%` operator could be useful, as
|
|
|
|
`String.format` does not have a way to manipulate the representation of numbers.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
+---------------------------------------------------------------------------+-------------------+
|
|
|
|
| **Example** | **Result** |
|
|
|
|
+---------------------------------------------------------------------------+-------------------+
|
2023-01-12 19:43:03 +01:00
|
|
|
| `"Hi, {0} v{version}".format({0:"Godette", "version":"%0.2f" % 3.114})` | Hi, Godette v3.11 |
|
2022-03-18 17:46:08 +01:00
|
|
|
+---------------------------------------------------------------------------+-------------------+
|