Python批量設(shè)定網(wǎng)絡(luò)機(jī)器

沉迷了好久的手游握截。拐邪。。差不多是時(shí)候務(wù)一下正業(yè)了氮帐。

目標(biāo)

自動(dòng)化網(wǎng)絡(luò)機(jī)器配置

工具

python
VBA

必須要吐槽一下我走過(guò)的那些彎路

由于完全不知道該用什么模塊嗅虏,邊查邊學(xué),每次都是撞一鼻子灰再換個(gè)方向上沐,鼻子都快給撞平了皮服。。
最開(kāi)始查到的是ConfigParser和paramiko
ConfigParser讀取登錄信息(用戶(hù)名参咙,密碼龄广,接口番號(hào),ip地址)蕴侧,paramiko建立鏈接并send show命令择同。。净宵。到此為止都很美好敲才,直到發(fā)現(xiàn)paramiko不識(shí)別set,delete塘娶,show |compare归斤,commit....
然后發(fā)現(xiàn)juniper有個(gè)自制的PyEZ,都帶EZ了肯定很好用對(duì)嗎5蟀丁脏里!
import的時(shí)候發(fā)現(xiàn)依存模塊lxml的etree加載不了。虹曙。迫横。至今仍是懸案番舆。。矾踱。
也不能總在死路里打轉(zhuǎn)恨狈。。呛讲。所以又開(kāi)始找別的代替模塊禾怠。。
皇天不負(fù)有心人贝搁。吗氏。。
讓我找到了pexpect雷逆。弦讽。。就直接發(fā)送文字列 簡(jiǎn)單粗暴膀哲。往产。。
雖然感覺(jué)寫(xiě)出來(lái)的東西毫無(wú)優(yōu)雅可言某宪。仿村。。
總之缩抡。奠宜。包颁。能用就成瞻想。。娩嚼。蘑险。(自暴自棄)

先寫(xiě)好python的部分


※[ ]中的部分可以任意修改為自己需要的數(shù)值


#!/usr/bin/env python
# -*- coding: utf-8 -*-
#=============================
import sys
import pexpect
#=============================
def Fnc_MAIN():
    print 'starting'
    #ssh鏈接,logfile=sys.stdout用于返回命令執(zhí)行結(jié)果
    ipaddr=sys.argv[1]
    command=pexpect.spawn('ssh [用戶(hù)名]@'+ipaddr,logfile=sys.stdout)
    command.expect('Password')
    command.sendline('[密碼]')
    command.expect('[host名]>')
    #事前l(fā)og
    command.sendline('[隨便寫(xiě)點(diǎn)show命令]')
    command.expect('[host名]>')
    command.sendline('[隨便寫(xiě)點(diǎn)show命令]')
    command.expect('[host名]>')
    command.sendline('[隨便寫(xiě)點(diǎn)show命令]')
    command.expect('[host名]>')
    command.sendline('[隨便寫(xiě)點(diǎn)show命令]')
    command.expect('[host名]>')
    command.sendline('configure')
    #command------------------
    command.expect('[host名]#')
    command.sendline('set interfaces ge-0/0/1 description qwer')
    command.expect('[host名]#')
    command.sendline('set interfaces ge-0/0/2 description qwer')
    command.expect('[host名]#')
    command.sendline('set interfaces ge-0/0/3 description qwer')
    command.expect('[host名]#')
    command.sendline('set interfaces ge-0/0/4 description qwer')
    command.expect('[host名]#')
    command.sendline('show |compare')
    command.expect('[host名]#')
    command.sendline('commit check')
    command.expect('[host名]#')
    command.sendline('commit')
    command.expect('[host名]#')
    command.sendline('exit')
    #事后log
    (和事前l(fā)og一樣岳悟,懶得寫(xiě)了佃迄。。)
    #Return ---------------------------
    return
# ================================================
# === Main =======================================
# --------------------------------------
if (__name__ == '__main__'):
    Fnc_MAIN()
    print ('\nFinish Script.')
# --------------------------------------
# ================================================

不要問(wèn)我為什么不用loop贵少。呵俏。。
你試試看滔灶。普碎。。
我也不知道為什么pexpect好像看不懂loop录平。麻车。缀皱。

VBA

由于這個(gè)腳本并不是那么自動(dòng)。动猬。所以決定用VBA來(lái)創(chuàng)建腳本
在EXCEL中輸入用戶(hù)名啤斗,密碼,命令行等信息赁咙,然后依據(jù)輸入值創(chuàng)建.py文本

工作表.png
Option Explicit

Sub makeText()
Dim ws As Worksheet
Set ws = ThisWorkbook.Worksheets(1)

Dim py As String
py = ActiveWorkbook.Path & "\config.py"

Open py For Output As #1

'ssh connect
Print #1, "#!/usr/bin/env python"
Print #1, "# -*- coding: utf-8 -*-"
Print #1, "#============================="
Print #1, "import sys"
Print #1, "import pexpect"
Print #1, "#============================="
Print #1, "def Fnc_MAIN():"
Print #1, "    print 'starting'"
Print #1, "    #login--------------------"
Print #1, "    ipaddr=sys.argv[1]"
Print #1, "    command=pexpect.spawn('ssh " & ws.Cells(2, 1).Value & "@'+ipaddr,logfile=sys.stdout)"
Print #1, "    command.expect('Password')"
Print #1, "    command.sendline('" & ws.Cells(4, 1).Value & "')"
Print #1, "    command.expect('" & ws.Cells(7, 1).Value & "')"

'log before send command
Print #1, "    #log----------------------"
Dim a As Long
a = 2
Do While ws.Cells(a, 2).Value <> ""
    Print #1, "    command.sendline('" & ws.Cells(a, 2).Value & "')"
    Print #1, "    command.expect('" & ws.Cells(7, 1).Value & "')"
    a = a + 1
Loop
Print #1, "    command.sendline('configure')"

'execute command
Print #1, "    #command------------------"
Dim b As Long
b = 2
Do While ws.Cells(b, 3).Value <> ""
    Print #1, "    command.expect('" & ws.Cells(8, 1).Value & "')"
    Print #1, "    command.sendline('" & ws.Cells(b, 3).Value & "')"
    b = b + 1
Loop

'log after commit
Print #1, "    #log----------------------"
Dim c As Long
c = 2
Do While ws.Cells(c, 4).Value <> ""
    Print #1, "    command.expect('" & ws.Cells(7, 1).Value & "')"
    Print #1, "    command.sendline('" & ws.Cells(c, 4).Value & "')"
    c = c + 1
Loop
Print #1, "    command.expect('" & ws.Cells(7, 1).Value & "')"
Print #1, "    #Return ---------------------------"
Print #1, "    return"
Print #1, "# ================================================"
Print #1, "# === Main ======================================="
Print #1, "# --------------------------------------"
Print #1, "if (__name__ == '__main__'):"
Print #1, "    Fnc_MAIN()"
Print #1, "    print ('\nFinish Script.')"
Print #1, "# --------------------------------------"
Print #1, "# ================================================"

Close #1

MsgBox "Successfully completed"

End Sub

終わりに

看別人教程的時(shí)候最討厭代碼一貼完事的那種钮莲。。
輪到自己了也是多一行都不想寫(xiě)
感恩那些寫(xiě)了很詳細(xì)的說(shuō)明的博主彼水。臂痕。。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末猿涨,一起剝皮案震驚了整個(gè)濱河市握童,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌叛赚,老刑警劉巖澡绩,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異俺附,居然都是意外死亡肥卡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)事镣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)步鉴,“玉大人,你說(shuō)我怎么就攤上這事璃哟》兆粒” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵随闪,是天一觀(guān)的道長(zhǎng)阳似。 經(jīng)常有香客問(wèn)我,道長(zhǎng)铐伴,這世上最難降的妖魔是什么撮奏? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮当宴,結(jié)果婚禮上畜吊,老公的妹妹穿的比我還像新娘。我一直安慰自己户矢,他們只是感情好玲献,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般青自。 火紅的嫁衣襯著肌膚如雪株依。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天延窜,我揣著相機(jī)與錄音恋腕,去河邊找鬼。 笑死逆瑞,一個(gè)胖子當(dāng)著我的面吹牛荠藤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播获高,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼哈肖,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了念秧?” 一聲冷哼從身側(cè)響起淤井,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎摊趾,沒(méi)想到半個(gè)月后币狠,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡砾层,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年漩绵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肛炮。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吁朦,死狀恐怖二汛,靈堂內(nèi)的尸體忽然破棺而出愈污,到底是詐尸還是另有隱情回季,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布粟害,位于F島的核電站蕴忆,受9級(jí)特大地震影響颤芬,放射性物質(zhì)發(fā)生泄漏悲幅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一站蝠、第九天 我趴在偏房一處隱蔽的房頂上張望汰具。 院中可真熱鬧,春花似錦菱魔、人聲如沸留荔。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)聚蝶。三九已至杰妓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碘勉,已是汗流浹背巷挥。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留验靡,地道東北人倍宾。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像胜嗓,于是被迫代替她去往敵國(guó)和親高职。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容