Lua和Python在十六进制转换方面的差异

在Python中,我有:

>>> mac_string = "68:a8:6d:0b:90:46"
>>> mac_int = int((mac_string).replace(":", ""), 16)
>>> print(mac_int)
115072593268806

在Lua中,我有:

> mac_string = "68:a8:6d:0b:90:46"
> mac_int = tonumber(mac_string:gsub(':',''),16)
> print(mac_int)
1.1507259326881e+14

为什么有4个差别?

点赞
用户100297
用户100297

到Lua 5.2版本为止,Lua的_number_类型使用浮点数表示,而Python使用的是实际的整数,只受内存限制。根据《Lua 5.2文档》

数字表示实数(双精度浮点数)。

要注意的是,该数字仍足够精确,但会 _四舍五入显示_。如果你在Python中将结果整数转换为浮点数(Python也使用双精度浮点数),你会发现相同的数字在那里:

>>> float(115072593268806)
115072593268806.0
>>> '{:.13e}'.format(float(115072593268806))
'1.1507259326881e+14'

第二行按照Lua所做的方式格式化数字;小数点后有13位数字,使用科学计数法。

你可以使用 string.format 让Lua使用不同的格式打印数字:

print(string.format("%d", mac_int))

我发现Lua 5.3扩展了_number_类型以支持64位整数,所以升级到该版本可能会解决这个问题。

2015-12-04 16:37:59
用户646619
用户646619

Lua 5.1 默认情况下,总是将数字存储为 64 位浮点数。 tostring 在打印非常大或非常小的值时使用科学计数法。

如果您使用 string.format 格式化数字,则可以得到所有数字:

> print(string.format("%15d", mac_int))
115072593268806
2015-12-04 16:40:41
用户1009479
用户1009479

你可能正在使用 Lua 5.2 或更低版本。数字类型在 C 语言中默认为 double 类型。print 的默认格式不具备足够的精度。


Lua 5.3 支持整数子类型,默认情况下为 64 位。同样代码的结果输出为:

115072593268806
2015-12-04 16:42:49