[Expect Script]为每个设备分隔日志文件

时间:2015-12-02 04:05:04

标签: expect cisco logfile juniper-network-connect

我的代码是为多个设备输出的一个日志文件生成的。

我们如何为每个日志文件输出分隔每个设备?

这是我的代码:

#!/usr/bin/expect -f
#Slurp up the input file
set fp [open "ip.txt" r]
# To avoid empty lines, 'nonewline' flag is used
set file_data [read -nonewline $fp]
close $fp
set prompt ">"
log_file -noappend router_status.txt
foreach ip [split $file_data "\n"] {
    puts "Router $ip Interface Status"
    spawn telnet $ip
    expect "Username:"
    send "username\r"
    expect "assword:"
    send "password\r"
    expect $prompt
    # To avoid sending 'Enter' key on huge configurations
    send "show interface description\r"
    expect {
    -ex "---(more" { send -- " "; exp_continue }
    "*>" { send "exit\r" }
    }
    set timeout 3; # Reverting to default timeout
    # Sending 'exit' at global level prompt will close the connection
    expect eof
    }

1 个答案:

答案 0 :(得分:1)

您可以通过更改log_file

来实现
foreach ip [split $file_data "\n"] {
    puts "Router $ip Interface Status"
    spawn telnet $ip

    # Altering 'log_file' for each ip
    log_file -noappend router_${ip}_status.log

    # Your further code here...


}