我目前正在尝试解析文件。它看起来像这样:
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代码),因为许多行都遵循该模式。
我做错了什么?
答案 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 .. "|(.-)|(.-)|(.-)|(.-)$"