使用Lua解析.txt文件。最基本的解析方式。

我正在尝试解析一个文件,它看起来像这样:

A|00CA|GOLDSTONE GTS|35350525|-116888367|3038
R|04|37|6000|0|0|0|35349333|-116893334|3038|300|50
R|22|217|6000|0|0|0|35360333|-116877500|3038|300|50

A|00WI|NORTHERN LITE|44304283|-89050111|860
R|09|90|1000|0|0|0|44304217|-89052022|860|300|50
R|27|270|1000|0|0|0|44304350|-89048208|860|300|50

A|01ID|LAVA HOT SPRINGS|42608250|-112032461|5268
R|14|143|2894|0|0|0|42611000|-112034867|5268|300|50
R|32|323|2894|0|0|0|42603733|-112030533|5268|300|50

A|01LS|COUNTRY BREEZE|30722639|-91077361|125
R|09|91|1800|0|0|0|30722747|-91080222|125|300|50
R|27|271|1800|0|0|0|30722531|-91074500|125|300|50

A|01MT|CRYSTAL LAKES RESORT|48789131|-114880436|3141
R|13|131|5000|0|0|0|48794975|-114885842|3141|300|50
R|31|311|5000|0|0|0|48783292|-114875003|3141|300|50

但更长,不过你已经知道了。

假设我想仅使用四位数代码从中获取整行数据。

因此,当用户键入00CA时,它将提取以下整个行并将其分解成"|"之间的数字或字母:

A|00CA|GOLDSTONE GTS|35350525|-116888367|3038

我已经得到了以下代码:

file = assert(io.open("Airports.txt", "r"))
for line in file:lines() do
  fields = { line:match "(%w+)|(%w+)|([%w ]+)|([%d-]+)|([%d-]+)|([%d-]+)" }
  print(fields[4], fields[5])  -- 你感兴趣的2个数字字段
end
file:close()

在这一整行中:

A|00CA|GOLDSTONE GTS|35350525|-116888367|3038

我只对获取这些数据感兴趣:35350525:-116888367

但是,当我尝试放置这个代码或类似的代码时,它只会输出空值。

-- ICAO == "00CA"
fields = { line:match "(%w+)|" .. ICAO .. "|([%w ]+)|([%d-]+)|([%d-]+)|([%d-]+)" }

显然,你需要放置一些自定义数据(ICAO代码)作为许多行都遵循该模式。

我做错了什么?

点赞
用户107090
用户107090

将调用放在括号内:

line:match("(%w+)|" .. ICAO .. "|([%w ]+)|([%d-]+)|([%d-]+)|([%d-]+)")

原始代码解析为

(line:match "(%w+)|") .. ICAO .. "|([%w ]+)|([%d-]+)|([%d-]+)|([%d-]+)"

下面是我测试的完整代码:

line="A|00CA|GOLDSTONE GTS|35350525|-116888367|3038"
ICAO = "00CA"
print(line:match("(%w+)|" .. ICAO .. "|([%w ]+)|([%d-]+)|([%d-]+)|([%d-]+)"))

输出结果为:

A   GOLDSTONE GTS   35350525    -116888367  3038

对于这个任务,我会使用一个更简单的模式:"(.-)|" .. ICAO .. "|(.-)|(.-)|(.-)|(.-)$"

2013-07-25 01:09:29