使用Lua解析.text文件。最基本的解析

时间:2013-07-25 00:53:55

标签: parsing lua

我目前正在尝试解析文件。它看起来像这样:

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])  -- the 2 numeric fields you're interested in
end
file:close()

这一行:

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

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

然而,当我尝试把这个或类似的东西。它只是输出零值。

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

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

我做错了什么?

1 个答案:

答案 0 :(得分:0)

在通话中添加括号:

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 .. "|(.-)|(.-)|(.-)|(.-)$"