string.Format


C#格式化数值结果表

字符

说明

示例

输出

C货币string.Format("{0:C3}", 2)$2.000
D十进制string.Format("{0:D3}", 2)002
E科学计数法1.20E+0011.20E+001
G常规string.Format("{0:G}", 2)2
N用分号隔开的数字string.Format("{0:N}", 250000)250,000.00
X十六进制string.Format("{0:X000}", 12)C


string.Format("{0:000.000}", 12.2)012.200

Strings

There really isn't any formatting within a strong, beyond it's alignment. Alignment works for any argument being printed in a String.Format call.

 

SampleGenerates
String.Format("->{1,10}<-", "Hello");-> Hello<-
String.Format("->{1,-10}<-", "Hello");->Hello <-

Numbers

Basic number formatting specifiers:

 

SpecifierTypeFormat

Output
(Passed
Double 1.42)

Output
(Passed
Int -12400)

cCurrency{0:c}$1.42-$12,400
dDecimal (Whole number){0:d}System.
FormatException
-12400
eScientific{0:e}1.420000e+000-1.240000e+004
fFixed point{0:f}1.42-12400.00
gGeneral{0:g}1.42-12400
nNumber with commas for thousands{0:n}1.42-12,400
rRound trippable{0:r}1.42System.
FormatException
xHexadecimal{0:x4}System.
FormatException
cf90

Custom number formatting:

 

SpecifierTypeExample Output (Passed Double 1500.42)Note
0Zero placeholder{0:00.0000}1500.4200Pads with zeroes.
#Digit placeholder{0:(#).##}(1500).42
.Decimal point{0:0.0}1500.4
,Thousand separator{0:0,0}1,500Must be between two zeroes.
,.Number scaling{0:0,.} 2Comma adjacent to Period scales by 1000.
%Percent{0:0%}150042%Multiplies by 100, adds % sign.
eExponent placeholder{0:00e+0}15e+2Many exponent formats available.
;Group separatorsee below 

The group separator is especially useful for formatting currency values which require that negative values be enclosed in parentheses. This currency formatting example at the bottom of this document makes it obvious:

Dates

Note that date formatting is especially dependant on the system's regional settings; the example strings here are from my local locale.

 

SpecifierTypeExample (Passed System.DateTime.Now)
dShort date10/12/2002
DLong dateDecember 10, 2002
tShort time10:11 PM
TLong time10:11:29 PM
fFull date & time December 10, 2002 10:11 PM
FFull date & time (long)December 10, 2002 10:11:29 PM
gDefault date & time10/12/2002 10:11 PM
GDefault date & time (long)10/12/2002 10:11:29 PM
MMonth day patternDecember 10
rRFC1123 date stringTue, 10 Dec 2002 22:11:29 GMT
sSortable date string2002-12-10T22:11:29
uUniversal sortable, local time2002-12-10 22:13:50Z
UUniversal sortable, GMTDecember 11, 2002 3:13:50 AM
YYear month patternDecember, 2002

The 'U' specifier seems broken; that string certainly isn't sortable.

Custom date formatting:

 

SpecifierTypeExample Example Output
ddDay{0:dd}10
dddDay name{0:ddd}Tue
ddddFull day name{0:dddd}Tuesday
f, ff, ...Second fractions{0:fff}932
gg, ...Era{0:gg}A.D.
hh2 digit hour{0:hh}10
HH2 digit hour, 24hr format{0:HH}22
mmMinute 00-59{0:mm}38
MMMonth 01-12{0:MM}12
MMMMonth abbreviation{0:MMM}Dec
MMMMFull month name{0:MMMM}December
ssSeconds 00-59{0:ss}46
ttAM or PM{0:tt}PM
yyYear, 2 digits{0:yy}02
yyyyYear{0:yyyy}2002
zzTimezone offset, 2 digits{0:zz}-05
zzzFull timezone offset{0:zzz}-05:00
:Separator{0:hh:mm:ss}10:43:20
/Separator{0:dd/MM/yyyy}10/12/2002

Enumerations

 

SpecifierType
gDefault (Flag names if available, otherwise decimal)
fFlags always
dInteger always
xEight digit hex.

Some Useful Examples

String.Format("{0:$#,##0.00;($#,##0.00);Zero}", value);

This will output "$1,240.00" if passed 1243.50. It will output the same format but in parentheses if the number is negative, and will output the string "Zero" if the number is zero.

String.Format("{0:(###) ###-####}", 18005551212);

This will output "(800) 555-1212".

 

变量.ToString()


字符型转换 转为字符串
12345.ToString("n"); //生成 12,345.00
12345.ToString("C"); //生成 ¥12,345.00
12345.ToString("e"); //生成 1.234500e+004
12345.ToString("f4"); //生成 12345.0000
12345.ToString("x"); //生成 3039 (16进制)
12345.ToString("p"); //生成 1,234,500.00%

<think>我们正在讨论Lua的string.format函数。根据引用,我们知道这个函数用于格式化字符串,比使用".."操作符连接字符串在某些情况下更灵活和可读,尤其是当需要特定格式转换(如十六进制、补零等)时。 函数定义: string.format(formatstring, ...) 第一个参数是格式字符串,包含占位符(如%d, %s等),后续参数用于替换这些占位符。 常用占位符: %d - 整数 %f - 浮点数 %s - 字符串 %x - 十六进制(小写字母) %X - 十六进制(大写字母) %% - 百分号本身 特殊格式控制(以%d为例): %02d - 表示整数至少显示两位,不足两位在前面补0 %-3d - 表示左对齐,宽度为3,不足用空格填充 示例: 1. 整数补零:string.format("%02d", 1) -> "01" 2. 左对齐:string.format("%-3d", 22) -> "22 "(后面有一个空格) 虽然string.format在性能上可能比".."稍差(因为它调用了C函数),但在复杂格式化时提高了可读性。 下面我们通过一些示例来详细说明用法。</think>### Lua `string.format` 字符串格式化详解 `string.format()` 是 Lua 中用于格式化字符串的核心函数,特别适合处理复杂格式或需要特定转换的场景。相比简单的 `..` 连接操作,它提供更强大的格式化能力[^1][^2]。 #### 基本语法 ```lua local result = string.format(format_string, arg1, arg2, ...) ``` - **format_string**:包含占位符的格式字符串 - **arg1, arg2...**:替换占位符的实际值 #### 常用占位符 | 占位符 | 说明 | 示例 | 输出结果 | |--------|---------------------|--------------------------|----------------| | `%d` | 十进制整数 | `string.format("%d", 25)`| `"25"` | | `%f` | 浮点数 | `string.format("%.2f", math.pi)` | `"3.14"` | | `%s` | 字符串 | `string.format("Hello %s", "Lua")` | `"Hello Lua"` | | `%x` | 十六进制(小写) | `string.format("%x", 255)` | `"ff"` | | `%X` | 十六进制(大写) | `string.format("%X", 255)` | `"FF"` | | `%%` | 百分号本身 | `string.format("50%% off")` | `"50% off"` | #### 高级格式控制 1. **数字补零**(固定位数显示): ```lua print(string.format("ID: %03d", 7)) -- ID: 007 print(string.format("Hex: %04X", 15)) -- Hex: 000F ``` 2. **对齐控制**: ```lua -- 左对齐(宽度10) print(string.format("|%-10s|", "Lua")) -- |Lua | -- 右对齐(宽度10) print(string.format("|%10s|", "Lua")) -- | Lua| ``` 3. **浮点数精度**: ```lua print(string.format("Pi: %.4f", math.pi)) -- Pi: 3.1416 print(string.format("Ratio: %.1f%%", 85.32)) -- Ratio: 85.3% ``` 4. **多参数组合**: ```lua local name, age = "Alice", 30 local msg = string.format("%s is %d years old (%02d/%02d)", name, age, 5, 3) -- Alice is 30 years old (05/03) ``` #### 性能注意事项 虽然 `string.format()` 比 `..` 连接操作性能稍低(底层调用 C 函数 `str_format`)[^3],但在以下场景仍推荐使用: - 需要数字格式化(补零、十六进制转换等) - 长字符串拼接(提高可读性) - 需要精确控制输出格式时 ```mermaid graph LR A[字符串格式化需求] --> B{简单拼接?} B -->|是| C[使用 .. 操作符] B -->|否| D{需要特殊格式?} D -->|是| E[使用 string.format] D -->|否| F[考虑 table.concat] ``` #### 实际应用示例 ```lua -- 表格数据格式化输出 local data = { { "Apple", 2.49, 10 }, { "Banana", 1.29, 25 }, { "Orange", 3.99, 8 } } for _, item in ipairs(data) do print(string.format("| %-10s | $%5.2f | %03d |", item[1], item[2], item[3])) end -- 输出: -- | Apple | $ 2.49 | 010 | -- | Banana | $ 1.29 | 025 | -- | Orange | $ 3.99 | 008 | ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值