GDScript offers a feature called format strings, which allows reusing text templates to succinctly create different but similar strings.

格式化字符串就像正常的字符串,除了他们包含某些占位符字符片段。 这些占位符可以轻易地被传递过来的参数替代。

举一个例子,使用 %s 作为占位符,格式化字符串 "Hello %s, how are you? 可以很容易改为 "Hello World, how are you?" 。注意占位符在字符串的中间,如果不使用格式化字符串去修改这个字符串可能会有点麻烦。(nice design)

在GDScript中的用法

来仔细看看这个具体的GDScript示例:

# 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
var actual_string = format_string % "Godot" print(actual_string)
# Output: "We're waiting for Godot."

占位符总是以 % 为开头,由下一个字符或字符串,即 格式说明符 ,决定给定值如何转化为一个字符串。

上述例子中的 %s 是最简单的占位符, 在大多数情况下使用:它通过隐式字符串转换方法或 str() 来转换值。 字符串保持不变, 布尔运算变为 "True" 或 "False", 整数或实数变为小数,其他类型通常以可读的字符串返回它们的数据。

在 GDScript 中还有另一种格式化文本的方式,也就是 String.format()方法。它用相应的值替换所有在字符串中出现的键。这个方法可以处理键/值对应的数组或字典。

数组可以用作键,索引或混合样式(请参见下面的例子)。仅当使用数组的索引或混合样式时,顺序才是重要的。

一个简单的 GDScript 例子:

# Define a format string
var format_string = "We're waiting for {str}" # Using the 'format' method, replace the 'str' placeholder
var actual_string = format_string.format({"str": "Godot"}) print(actual_string)
# Output: "We're waiting for Godot"

还有其他的 格式说明符, 但只有在使用 % 操作符的情况下才适用。

占位符类型

有且只有其中一个作为最后一个字符在格式说明符中出现。除了 s外, 这些格式说明符还需要某些类型的参数。

s 简单的字符串转换,通过相同的隐式字符串转换方法。
c 单个 Unicode 字符。对于代码点或单个字符, 需要一个无符号的8位整数 (0-255) 。
d 一个 十进制 整数。 需要一个整数或实数(向下取整)。
o 一个 八进制 整数。 需要一个整数或实数(向下取整)。
x 一个小写字母的 十六进制 整数。 需要一个整数或实数(向下取整)。
X 一个大写字母的 十六进制 整数。 需要一个整数或实数(向下取整)。
f 一个 十进制 实数。 需要一个整数或实数。

占位符的修饰符

这些字符在上述占位符前出现。 其中一些只在特定情况下生效。

+ 用在数字说明符中,如果为正 显示+号 。
Integer 设置 填充 。用空格填充,或如果整数 0 写在一个整数占位符中用0填充。当 . 使用时见 . 。
. ``f``之前,设置 精度 到0位小数。可以跟进数量改变。用零填充。
- 向右填充 而不是向左。
* 动态填充, 期望额外的整数参数来设置填充或 . 后的精度。见 dynamic padding

填充

字符 . (点), * (星号), - (减号) 和 数字 (0-9) 被用作占位符。使一列定宽字体的值在垂直方向上可以保持对齐。

要使字符串满足一个最小长度,需要在标识符前添加一个整数:

print("%10d" % 12345)
# output: " 12345"
# 5 leading spaces for a total length of 10

如果这个整数以0开头,那么整数值字符串将前置填充0,而不是空格:

print("%010d" % 12345)
# output: "0000012345"

可以通过添加 . ()和一个整数来指定实数的精度。``.``后没整数时,精度为0,舍入为整数值。要用于填充的整数则必须出现在点之前。

# Pad to minimum length of 10, round to 3 decimal places
print("%10.3f" % 10000.5555)
# Output: " 10000.556"
# 1 leading space

- 字符将导致向右而不是向左填充,对右文本对齐很有用:

print("%-10d" % 12345678)
# Output: "12345678 "
# 2 trailing spaces

动态填充

通过使用 * ( 星号 )字符,可以在不修改格式字符串的情况下设置填充或精度。 它用于代替格式说明符中的整数。 然后在格式化时传递填充和精度的值:

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

通过在 * 之前添加 0 ,仍然可以在整数占位符中填充零:

print("%0*d" % [2, 3])
#output: "03"

逃脱序列

要在文本字符串中插入文字 % 字符,必须对其进行转义以避免将其作为占位符读取。 这是通过加倍符号来完成的:

var health = 56
print("Remaining health: %d%%" % health)
# Output: "Remaining health: 56%"

格式化方法示例

以下是如何使用 String.format 方法的各种调用的一些示例。

类型 样式 示例 结果
字典 "Hi, {name} v{version}!".format({"name":"Godette", "version":"3.0"}) Hi, Godette v3.0!
字典 索引 "Hi, {0} v{1}!".format({"0":"Godette", "1":"3.0"}) Hi, Godette v3.0!
字典 混合 "Hi, {0} v{version}!".format({"0":"Godette", "version":"3.0"}) Hi, Godette v3.0!
数组 "Hi, {name} v{version}!".format([["version","3.0"], ["name","Godette"]]) Hi, Godette v3.0!
数组 索引 "Hi, {0} v{1}!".format(["Godette","3.0"]) Hi, Godette v3.0!
数组 混合 "Hi, {name} v{0}!".format([3.0, ["name","Godette"]]) Hi, Godette v3.0!
数组 没有索引 "Hi, {} v{}!".format(["Godette", 3.0], "{}") Hi, Godette v3.0!

占位符也可以在使用 String.format 时进行自定义, 下面是该功能的一些示例。

类型 示例 结果
中缀(默认) "Hi, {0} v{1}".format(["Godette", "3.0"], "{_}") Hi, Godette v3.0
后缀 "Hi, 0% v1%".format(["Godette", "3.0"], "_%") Hi, Godette v3.0
前缀 "Hi, %0 v%1".format(["Godette", "3.0"], "%_") Hi, Godette v3.0

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.

示例 结果
"Hi, {0} v{version}".format({0:"Godette", "version":"%0.2f" % 3.114}) Hi, Godette v3.11

GDScript 格式化字符串的更多相关文章

  1. VBA 格式化字符串 - Format大全

    VBA 格式化字符串 VBA 的 Format 函数与工作表函数 TEXT 用法基本相同,但功能更加强大,许多格式只能用于VBA 的 Format 函数,而不能用于工作表函数 TEXT ,以下是本人归 ...

  2. Python中用format函数格式化字符串

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存. 1.百分号方式 语法:%[( ...

  3. C#定义类型转化 及 格式化字符串

    operator 关键字 operator 关键字用来重载内置运算符,或提供类/结构声明中的用户定义转换.它可以定义不同类型之间采用何种转化方式和转化的结果. operator用于定义类型转化时可采用 ...

  4. 关于printf错用格式化字符串导致double和long double输出错误的小随笔

    [题外话] 以前用HUSTOJ给学校搭建Online Judge,所有的评测都是在Linux下进行的.后来为了好往学校服务器上部署,所以大家重新做了一套Online Judge,Web和Judge都是 ...

  5. .NET中DateTime.Now.ToString的格式化字符串

    .NET中DateTime.Now.ToString显示毫秒:DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") DateTime.N ...

  6. Python格式化字符串~转

    Python格式化字符串 在编写程序的过程中,经常需要进行格式化输出,每次用每次查.干脆就在这里整理一下,以便索引. 格式化操作符(%) "%"是Python风格的字符串格式化操作 ...

  7. %----format 格式化字符串---- 生成器---- 迭代器

    %方式格式化字符串 顺序传参数 o转换8进制x转换十六进制 tp1 = "i am %s" % "alex"tp2 = "i am %s age %d ...

  8. 飘逸的python - 增强的格式化字符串format函数

    自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓威力十足.那么,他跟之前的%型格式化字符串相比,有什么优越的存在呢?让我们来揭开它羞答答的面纱. 语法 它通过{}和 ...

  9. Python格式化字符串和转义字符

    地址:http://blog.chinaunix.net/uid-20794157-id-3038417.html Python格式化字符串的替代符以及含义     符   号     说     明 ...

随机推荐

  1. 当我们直接打印定义的对象的时候,隐含的是打印toString()的返回值。

      以下介绍的三种方法属于Object: (1)  finalize方法:当一个对象被垃圾回收的时候调用的方法. (2)  toString():是利用字符串来表示对象. 当我们直接打印定义的对象的时 ...

  2. win2003 序列号 windows2003 sp2可用序列号大全(准版与企业版)

    通用性好的win2003序列号: (推荐先用这个里面的) FJ8DH-TQPYG-9KFHQ-88CB2-Y7V3Y GRD4P-FTQQF-JCDM8-4P6JK-PFG7M JD7JX-KCDTH ...

  3. [转]SASS用法指南

    [转]SASS用法指南 转自阮一峰 SASS用法指南 一.什么是SASS SASS是一种CSS的开发工具,提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发,变得简单和可维护. 本文总结了 ...

  4. STS中如何使用lombok

    Lombok有什么用使用Lombok时需要注意的点Lombok的安装spring boot集成LombokLombok常用注解@NonNull@Cleanup@Getter/@Setter@Gette ...

  5. 《转载》JVM垃圾回收机制

    本文转载自ImportNew - 郑雯 每个Java程序员迟早都会碰到下面这个错误: java.lang.OutOfMemoryError 这个时候一般会建议采用如下方式解决这个错误: 增加MaxPe ...

  6. kaggle竞赛-保险转化-homesite

    时间格式的转化 查看数据类型 查看DataFrame的详细信息 填充缺失值 category 数据类型转化 模型参数设定 结论 该项目是针对kaggle中的homesite进行的算法预测,使用xgbo ...

  7. Codeforces Round #496 (Div. 3)

    一如既往地四题...好久没切了 有点犯困了明显脑子感觉不够灵活. 为了熟练度还是用java写的,,,导致观赏性很差...我好不容易拉了个队友一起切结果过掉a就tm挂机了!!! A题竟然卡了,,,用了十 ...

  8. cloud_note项目

    导入mysql数据库: set names utf8; source cloud_note.sql 1.搭建springMvc+springIOc+Mybatis --引入jar包 ioc,aop,d ...

  9. loadrunner笔记(三):设置、运行场景和生成测试报告

    //上一篇的代码有点问题,问题出在 web_reg_find()函数中,这个函数简单的说是搜索下一步操作的请求对象(html)页面中是否存在相应的文本字符串.所以用在登录操作中,它搜索的是主页.htm ...

  10. mui 窗口管理及窗口之间的数据传递

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...