Как получить строку, используя сопоставление с образцом lua - PullRequest
0 голосов
/ 25 октября 2011

ниже - моя строка

local Amount =[[
Customer Details Net Amount
# Seq Name
Amount NTR
1 CDABCDEFGHIJ00564
0,1234
2 CDABCDEFGHIJ00565
0,0361
3 CDABCDEFGHIJ00566
0,0361
4 CDABCDEFGHIJ00567
0,0722
5 CDABCDEFGHIJ00568
0,0000
6 CDABCDEFGHIJ00569
0,0000
7 CDABCDEFGHIJ00570
0,0000
8 CDABCDEFGHIJ00571
0,7091
9 CDABCDEFGHIJ00572
1,4240
10 CDABCDEFGHIJ00573
0,0361
11 CDABCDEFGHIJ00574
0,5790
12 CDABCDEFGHIJ00575
0,4060
13 CDABCDEFGHIJ00576
0,3610
14 CDABCDEFGHIJ00577
0,6859
15 CDABCDEFGHIJ00578
0,2888
16 CDABCDEFGHIJ00579
0,0000
17 CDABCDEFGHIJ00580
0,0000
18 CDABCDEFGHIJ00581
0,0000
19 CDABCDEFGHIJ00582
0,0000
20 CDABCDEFGHIJ00583
0,0000
21 CDABCDEFGHIJ00584
0,0000
22 CDABCDEFGHIJ00585
0,8978
23 CDABCDEFGHIJ00586
0,0000
24 CDABCDEFGHIJ00587
2,3882
25 CDABCDEFGHIJ00588
0,0000
26 CDABCDEFGHIJ00589
2,0216
27 CDABCDEFGHIJ00590
1,7540
28 CDABCDEFGHIJ00591
0,0000
29 CDABCDEFGHIJ00592
0,0722
30 CDABCDEFGHIJ00593
0,0361
31 CDABCDEFGHIJ00594
0,0000
32 CDABCDEFGHIJ00595
0,0000
Total NAT files
11,9269
Direct inquiries to:
]]

, выполнив код ниже

local ptrn = '\n([%d%p]+)\n'
for val1, val2 in string.gmatch(Amount, ptrn) do

    print ("val1:=\t" .. (val1 or '').."\tval2:=\t"..(val2 or ''))

end

, в основном из приведенной выше строки. Я хочу получить последние 5 цифр строки, которая равна 00564 вval1 и количество, которое равно 0,1234 в переменной val2, но все это должно быть в одном паттерне.Это запись, каждая запись начинается с номера, подобного этому, это 1 запись или строка

1 CDABCDEFGHIJ00564
    0,1234

, а это 2-я запись или строка и т. Д.

 2 CDABCDEFGHIJ00565
    0,0361

Пожалуйста, помогите....

1 Ответ

1 голос
/ 25 октября 2011

Мне кажется, что %d+%s+%a+(%d+)\n%s*([%d,]+) должен сделать свое дело: первый %d+ поймает номер строки, %s+, чтобы соответствовать пробелу после.%a+(%d+) будет соответствовать CDABCDEFGHIJ00592 и захватывать цифры в конце (однако невозможно указать, что вы хотите ровно пять цифр).\n%s* будет соответствовать новой строке и любому пробелу на следующей строке, а ([%d,]+) будет захватывать последний номер с запятой.

...