0

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

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-]+)" }

很明显,您需要在其中放入一些自定义数据(国际民航组织代码),因为许多行都遵循该模式。

我究竟做错了什么?

4

1 回答 1

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

于 2013-07-25T01:09:29.993 回答