正如其他答案所说,Lua中的字符串连接运算符是两个点。
你的简单例子应该这样写:
filename = "checkbook"
filename = filename .. ".tmp"
然而,有一个警告需要注意。由于 Lua 中的字符串是不可变的,因此每次串联都会创建一个新的字符串对象,并将源字符串中的数据复制到其中。这使得连续连接到单个字符串的性能非常差。
这种情况下的 Lua 习惯用法是这样的:
function listvalues(s)
local t = { }
for k,v in ipairs(s) do
t[#t+1] = tostring(v)
end
return table.concat(t,"\n")
end
通过收集要连接在数组中的字符串t
,标准库例程table.concat
可用于将它们全部连接起来(以及每对之间的分隔符字符串),而无需进行不必要的字符串复制。
Update:我刚刚注意到我最初使用上面的代码片段编写了pairs()
代替ipairs()
.
正如最初所写,该函数listvalues()
确实会从传入的表中生成每个值,但不是以稳定或可预测的顺序。另一方面,它将包含其键在范围内不是正整数的值1
to #s
。就是这样pairs()
作用:它生成存储在表中的每个(键,值)对。
在大多数情况下,您会使用类似的东西listvaluas()
您可能有兴趣保留他们的订单。所以一个调用写成listvalues{13, 42, 17, 4}
将生成一个包含按顺序包含这些值的字符串。然而,pairs()
不会这样做,它会按照某种顺序逐项列出它们,具体取决于表数据结构的底层实现。众所周知,顺序不仅取决于钥匙,还取决于插入钥匙和移除其他钥匙的顺序。
当然ipairs()
也不是一个完美的答案。它仅枚举表中形成“序列”的那些值。也就是说,这些值的键形成从 1 到某个上限的不间断块,这(通常)也是由#
操作员。 (在很多情况下,函数ipairs()
本身最好用更简单的替换for
循环只从1
to #s
。这是 Lua 5.2 和 LuaJIT 中推荐的做法,其中更简单for
循环可以比循环更有效地实现ipairs()
迭代器。)
If pairs()
确实是正确的方法,那么通常的情况是您想要同时打印键和值。通过使数据具有自描述性,减少了对顺序的担忧。当然,因为任何 Lua 类型(除了nil
和浮点数NaN
)可以用作密钥(并且NaN
也可以存储为值)找到字符串表示形式作为学生的练习。并且不要忘记树和更复杂的表结构。