Это происходит из-за жадности ведущего .*
- потому что оно выскальзывает из максимально возможного числа символов, текст, оставшийся для части (\d+)
, представляет собой последнюю цифру. Вот демо, где я также запечатлел ведущую ". *":
expect1.11> exp_internal 1
expect1.12> spawn sh -c {echo foo; echo 1234; echo bar}
spawn sh -c echo foo; echo 1234; echo bar
parent: waiting for sync byte
parent: telling child to go ahead
parent: now unsynchronized from child
spawn: returns {78523}
78523
expect1.13> expect -re {(.*)(\d+).*}
Gate keeper glob pattern for '(.*)(\d+).*' is ''. Not usable, disabling the performance booster.
expect: does "" (spawn_id exp10) match regular expression "(.*)(\d+).*"? (No Gate, RE only) gate=yes re=no
foo
1234
bar
expect: does "foo\r\n1234\r\nbar\r\n" (spawn_id exp10) match regular expression "(.*)(\d+).*"? (No Gate, RE only) gate=yes re=yes
expect: set expect_out(0,string) "foo\r\n1234\r\nbar\r\n"
expect: set expect_out(1,string) "foo\r\n123"
expect: set expect_out(2,string) "4"
expect: set expect_out(spawn_id) "exp10"
expect: set expect_out(buffer) "foo\r\n1234\r\nbar\r\n"
Обратите внимание на то, что хранится в «1, строка» и «2, строка»
Решение состоит в том, чтобы упростить ваше регулярное выражение. Если вы просто хотите захватить первый набор цифр, используйте
expect -re {\d+}
set theNum $expect_out(0,string)
Или, если вы хотите захватить первые цифры , которые являются единственными символами в строке :
expect -re {\r\n(\d+)\r\n}
set theNum $expect_out(1,string)
Один урок здесь заключается в том, что в шаблонах регулярных выражений, как правило, вам не нужно вводить и заканчивать .*
подстановочными знаками: просто сосредоточьтесь на том, что вам нужно, чтобы захватить нужный текст.