3

我正在尝试将一串科学记数法数字转换为实际数字。

我的测试字符串格式如下:

myString = 1.000000000000000E+00,  2.000000000000000E+02,  -1.000000000000000E+05

我当前的代码:

elements = {}

for s in myString:gmatch('%d+%.?%d*') do
    table.insert(elements, s);
end

return unpack(elements);

Elements 错误地返回以下内容:

1.000000000000000     %from the first number before "E"
00                    %after the "E" in the first number
2.000000000000000     %from the second number before "E"

任何人都知道我该如何解决这个问题?

4

5 回答 5

2

对我来说,“实际数字”是指数字数据类型。tonumber()在科学记数法方面做得很好。

local myString = [[ 1.000000000000000E+00, 
 2.000000000000000E+02,  -1.000000000000000E+05 ]]
local function convert(csv)
    local list = {}
    for value in (csv .. ","):gmatch("(%S+)%W*,") do table.insert(list,tonumber(value)) end
    return unpack(list)
end
print(convert(myString))
于 2013-05-21T21:12:55.303 回答
1

试试这个:

for s in (myString..","):gmatch("(%S+),") do print(s) end
于 2013-05-21T19:54:51.443 回答
1

我建议使用gsplit这里定义的函数:SplitJoin,然后有一个像这样的循环:

t = {}
for number in gsplit(myString:gsub('%s',''),',') do
    t[#t+1] = tonumber(number)
end

哪个字符串:

myString = [[1.000000000000000E+00,  2.000000000000000E+02,  -1.000000000000000E+05]]

结果table.concat(t,',')是:

1,200,-100000
于 2013-05-22T09:38:04.153 回答
0

扩展模式以识别可选尾数并用于tonumber从字符串中获取数字:

elements = {}
myString = "1.000000000000000E+00,  2.000000000000000E+02,  -1.000000000000000E+05"
for s in myString:gmatch('[+%-]?%d+%.?%d*[eE+%-]*%d?%d?') do
    table.insert(elements, tonumber(s))
end
print(unpack(elements))
于 2013-05-21T21:16:38.310 回答
0

这是另一个答案,它很强大但可能有点矫枉过正:

f = loadstring("return {" .. myString .."}")
if f==nil then  end -- myString malformed
elements = f()
于 2013-05-22T11:15:32.043 回答