应同事需求自行编写了第一个脚本,中间遇到一些坑。

需求,要求抓取设备“show ip interface brief”信息和“show interface des”描述信息。并且要求VLAN与描述信息在一个文件中显示出来。其实抓取工作很简单,难点在于字符处理中遇到时很多坑,比如关键字"More“抓取之后会有类似于“^[[7m--More--^[[m^M”的多余字符,是因为系统版本原因产生的。要用sed将其处理为awk可以匹配的格式。

先上内容。

1,抓取“show ip interface brief”信息(show inter des命令直接替换)。

#!/usr/bin/expect

#set ip
set ipaddress [lindex $argv 0]

#set user
set name [lindex $argv 1]

#set passwd
set passwd [lindex $argv 2]

#set timeout
set timeout 2

#ssh process
spawn ssh $name@$ipaddress

#进行判断
expect {
"yes/no" { send "yes\r" }
"*assword:" { send "$passwd\r";exp_continue}
"*# " { send "show ip inter bri\r" }

while (1) {
expect {
"More--" { send " " }
"*#" { break }
     }
}
expect eof

2,字符处理脚本

用户名密码文件的格式为:

ip1 user1 passwd1

ip2 user2 passwd2

脚本如下:

#!/bin/bash
p=`pwd`
for i in `awk '{print $1}' $p/passwd`                           #取文件中第一列IP
do
j=`grep $i $p/passwd | awk '{print $2}'`
k=`grep $i $p/passwd | awk '{print $3}'`                   #j,k分别为取到的用户名,密码
echo "正在抓取"$i"的信息"
expect $p/ssh-brief.exp $i $j $k | grep Vlan > $p/brief/$i-bri.log                #将ip,j,k作为参数传给expect登录并取配置存入文件中
    if [ $? -eq 0 ];then
      echo $i"地址文件抓取成功,下一步抓取描述文件。"
    else
      echo $i"地址文件抓取失败,即将退出脚本"
    exit
    fi
expect $p/ssh-des.exp $i $j $k | grep Vlan > $p/des/$i-des.log
    if [ $? -eq 0 ];then
      echo $i"描述文件抓取成功成功"
    else
      echo $i"描述文件抓取失败,即将退出脚本"
    exit
    fi

echo "处理"$i"的地址文件"

sed -i 's/^.*Vlan/Vlan/g' $p/brief/$i-bri.log                #由于系统不同的原因产生了^[[7m--More--^[[m^M等多余字符这里对多余的字符进行处理。
    if [ $? -eq 0 ];then
      echo $i"地址文件处理成功"
    else
      echo $i"地址文件处理失败,即将退出脚本"
      exit
    fi
echo "处理"$i"的描述文件"
sed -i 's/^.*Vlan/Vlan/g' $p/des/$i-des.log
    if [ $? -eq 0 ];then
      echo $i"描述文件处理成功"
    else
      echo $i"描述文件处理失败,即将退出脚本"
      exit
    fi
echo "生成"$i"文件"
awk '{if(NR==FNR){i++;a1[i]=$1;a2[i]=$2;a3[i]=$3}else{j++;b1[j]=$1;b2[j]=$2" "$3" "$4}}END{for(m=0;m<=i;m++)for(n=0;n<=j;n++){if(a1[m]==b1[n]){print a1[m],a2[m],a3[m],b2[n]}}}' $p/brief/$i-bri.log $p/des/$i-des.log > $p/log/$i.log     #处理两个文件件合并为一个文件,以Vlan为标识对两个文件相同Vlan匹配后生成新文件
    if [ $? -eq 0 ];then
      sed -i "s/$(echo -e '\015')//g" $/log/$i.log                     #去除新生成文件中的^M字符。

        if [ $? -eq 0 ];then
          echo $i"---------------------------------------------------------------------成功"
    else
      echo "生成"$i"文件失败,即将退出。"
      exit
    fi

done

批量抓取cisco设备配置脚本编写(expect/sed/awk/shell)的更多相关文章

  1. Python3利用BeautifulSoup4批量抓取站点图片的代码

    边学边写代码,记录下来.这段代码用于批量抓取主站下所有子网页中符合特定尺寸要求的的图片文件,支持中断. 原理很简单:使用BeautifulSoup4分析网页,获取网页<a/>和<im ...

  2. 使用HtmlAgilityPack批量抓取网页数据

    原文:使用HtmlAgilityPack批量抓取网页数据 相关软件点击下载登录的处理.因为有些网页数据需要登陆后才能提取.这里要使用ieHTTPHeaders来提取登录时的提交信息.抓取网页  Htm ...

  3. Web自动化框架LazyUI使用手册(4)--控件抓取工具Elements Extractor详解(批量抓取)

    概述 前面的一篇博文详细介绍了单个控件抓取的设计思路&逻辑以及使用方法,本文将详述批量控件抓取功能. 批量抓取:打开一个web页面,遍历页面上所有能被抓取的元素,获得每个元素的iframe.和 ...

  4. 如何上传Packages到PyPI并批量抓取

    1.如何上传包到PyPI ? 更新中... 2.批量抓取simple网站第三方模块 https://pypi.python.org/simple/ 3. 第三方模块的安装和使用 python  set ...

  5. python实现列表页数据的批量抓取练手练手的

    python实现列表页数据的批量抓取,练手的,下回带分页的 #!/usr/bin/env python # coding=utf-8 import requests from bs4 import B ...

  6. Hibernate批量抓取

    ------------------siwuxie095 Hibernate 批量抓取 以客户和联系人为例(一对多) 1.批量抓取 同时查询多个对象的关联对象,是 Hibernate 抓取策略的一种 ...

  7. Hibernate学习---第十一节:Hibernate之数据抓取策略&批量抓取

    1.hibernate 也可以通过标准的 SQL 进行查询 (1).将SQL查询写在 java 代码中 /** * 查询所有 */ @Test public void testQuery(){ // ...

  8. Hibernate的批量抓取

    批量抓取理解:如果我们需要查找到客户的所有联系人的话,按照正常的思路,一般是首先查询所有的客户,得到返回的客户的List集合.然后遍历List集合,得到集合中的每一个客户,在取出客户中的联系人(客户表 ...

  9. day36 08-Hibernate抓取策略:批量抓取

    package cn.itcast.test; import java.util.List; import org.hibernate.Hibernate; import org.hibernate. ...

随机推荐

  1. SpringMVC的流程分析(一)—— 整体流程概括

    SpringMVC的整体概括 之前也写过springmvc的流程分析,只是当时理解的还不透彻所以那篇文章就放弃了,现在比之前好了些,想着写下来分享下,也能增强记忆,也希望可以帮助到人,如果文章中有什么 ...

  2. [PGM] Bayes Network and Conditional Independence

    2 - 1 - Semantics & Factorization 2 - 2 - Reasoning Patterns 2 - 3 - Flow of Probabilistic Influ ...

  3. chromium源码阅读--进程间通信(IPC)

    第一篇就有提到Chromium是目前默认是采用多进程架构,当然,chromium有singe-process的版本. 多进程与多线程的区别,确实有很多可以讲的,我的另一篇博客也讲了一些,这里是从浏览器 ...

  4. hive 创建表和导入数据实例

    //创建数据库create datebase hive;//创建表create table t_emp(id int,name string,age int,dept_name string,like ...

  5. 修改Jupyter notebook的启动目录

    修改Jupyter notebook的启动目录 1. 在控制台输入以下命令,检查Jupyter notebook的安装目录 jupyter notebook --generate-config ​ 如 ...

  6. HDU 6121 Build a tree(找规律+模拟)

    Build a tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others)To ...

  7. js中的浅复制和深复制

    浅复制:浅复制是复制引用,复制后的引用都是指向同一个对象的实例,彼此之间的操作会互相影响 深复制:深复制不是简单的复制引用,而是在堆中重新分配内存,并且把源对象实例的所有属性都进行新建复制,以保证深复 ...

  8. 利用HTML5新特性改变浏览器地址后不刷新页面

    原文:http://www.cnblogs.com/xuchengzone/archive/2013/04/18/html5-history-pushstate.html   作为一个程序员,上Git ...

  9. 原生 drag drop HTML5

    drag事件( dragstart -- drag -- dragend )   当按下鼠标开始drag一个可以拖动的对象时,触发dragstart事件,如果元素是不可拖动的话,会出现一个不可拖动的图 ...

  10. 介绍一款好用 mongodb 可视化工具

    最近想自己搭建一个个人博客,所以学了下mongodb,mongodb是用命令行输入的,有些人可能不太习惯,我自己找了下mongodb的一些可视化工具,一开始安装的是mongoVUE,mongoVUE页 ...