WedX - журнал о программировании и компьютерных науках

Ожидайте, что ведение журнала сценариев не завершится

У меня есть ожидаемый сценарий, который передает команды конфигурации из файла на маршрутизатор. Я записываю процесс в файл, однако ожидаю, что запись в журнал перестанет происходить до конца файла конфигурации. Например, если файл конфигурации имеет

q
r
s
t
u
v
w
x
y
z
eof

В журнале будут все взаимодействия до u, но остального в журнале нет, но похоже, что процесс завершен до z. Обычное сравнение конца файла, похоже, не работает, поэтому я попробовал следующее.

    set ok 0;
    while { $ok == 0 } {
      set line [ gets $config ];


       expect  { 
            "#" { send -s "$line\r"; }
            -re "\[.]" { send -s "$line\r"; }
        }
         if { $line == "eof" } {
           set ok 1;
        } else { }

   }
   close $config

Он устанавливает ok на 1 и оставляет оператор while, но скрипт прекращает ведение журнала до этого.

28.10.2013

  • Я установил expect_internal 1, файл журнала имеет следующее: ожидание: соответствует ли 52.0 25 (spawn_id exp8) шаблону glob #? нет [.]? (Без шлюза, только RE) gate=yes re=yes expect: set expect_out(0,string) . ожидание: установить ожидание_out(spawn_id) exp8 ожидание: установить ожидание_out(буфер) 52. send: отправка записи в память\r в { exp8 } Вы можете видеть, что код получает оператор записи памяти в файле, но фактические команды не получают в устройство. Он перестает входить в линию. [.] есть, потому что иногда нет #, потому что они вводят строку баннера, поэтому там просто пусто. 29.10.2013

Ответы:


1

Это занимает слишком много времени? Причина, по которой я спрашиваю, заключается в том, что, возможно, время ожидания истекло из-за того, что ни один из вариантов в вашем выражении ожидания не соответствует (первый вариант соответствует подсказке «#» ... чему должен соответствовать второй вариант?), и в этом случае, после ожидаемого времени out в каждом проходе, код по-прежнему просматривал бы все строки в вашем конфигурационном файле и в конечном итоге достигал eof и устанавливал ok на 1.

Вот что я бы сделал:

  • включите expect_internal 1 где-нибудь в начале вашего скрипта, чтобы получить представление о том, что происходит
  • удалите точки с запятой после вашего набора и отправьте операторы... afaik expect не использует их (я думал, что он будет жаловаться!)
  • добавьте параметр timeout (3-й вариант) в ваш оператор ожидания и, возможно, напечатайте что-то соответственно, если оно туда попадет

Я предполагаю, что список команд, который вы называете «q r s t u v w x y z eof», не является однострочным, а состоит из одной команды в строке, верно?

Кроме того, я предполагаю, что у вас есть set config [open "/path/to/filename.txt"] где-то в верхней части вашего скрипта, и вы не показываете его в своем фрагменте?

Не стесняйтесь публиковать все, что вы получите после добавления exp_internal 1, если вам нужна помощь в этом.

28.10.2013
Новые материалы

Как создать диаграмму градиентной кисти с помощью D3.js
Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


Для любых предложений по сайту: [email protected]