python用paramiko将执行的结果存入excel表格
一、paramiko
利用paramiko可以远程控制服务器,上传和下载文件。
1、paramiko密码登录方式:
#!/usr/bin/env python
#coding:utf-8import paramiko ssh = paramiko.SSHClient() #创建链接
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
#在远程服务器上设置签名。第一次登录服务器时,会输入YES/No
#在用户目录/.ssh/known_hosts文件里会有主机的登录签名。如果没有记录,在第一次登录时显示YES/NO
ssh.connect('192.168.1.108', 22, 'alex', '') #连接输入的信息
stdin, stdout, stderr = ssh.exec_command('df') #执行命令
print stdout.read() #打印结果
ssh.close(); #关闭链接
paramiko密码登录
2、paramiko密钥对登录方式:
密钥的方式,
1.生成密钥对
2.将自己的公钥传至目标服务器
3.提取自己私钥的路径
4.建立连接
ssh-keygen -t rsa #生成一个自己的公钥
ssh-copy-id -i chenchao@192.168.1.100 #发送自己的公钥到目标服务器的登录用户的家目录下,默认会到当前用户的目录下去找公钥 ~/.ssh/id_rsa.pub,下次在登录时就不在需要密码了 import paramiko private_key_path = '/root/.ssh/id_rsa' #声明自己的私钥在哪里 private:私有的
key = paramiko.RSAKey.from_private_key_file(private_key_path) #取出私钥,保存
ssh = paramiko.SSHClient() #创建链接
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #第一次登录时,自动设置签名 YES/NO
ssh.connect('主机名 ', 端口, username='用户名', pkey=key) #登录的信息
stdin, stdout, stderr = ssh.exec_command('df') #执行命令
print stdout.read()
ssh.close()
paramiko密钥对登录
3、远程上传下载文件:
#!/usr/bin/env python
#conding:utf-8 import paramiko t = paramiko.Transport(('192.168.1.107',22)) #创建链接
t.connect(username='root',password='pwd@123') #输入目标服务器的用户名和密码 sftp = paramiko.SFTPClient.from_transport(t) #生成连接对象 sftp.put('/python/coder/connect.py','/opt/test.py') #上传 源地址文件 目标地址文件
#sftp.get('/opt/123.txt','/python/coder/123.txt') #下载
t.close()
paramiko传送文件
1、先将执行的结果放入一个文件中
2、逐行读取文件,将每行的内容按照空格分割成列表
3、在利用csv模块方法,将分割的列表写入到csv后缀的表格文件中
二、将paramiko执行的结果放入excel表格文件里
1、python中自带csv模块
- 用python读取csv文件
csv是逗号分隔符格式 一般我们用的execl生成的格式是xls和xlsx 直接重命名为csv的话会报错:
Error: line contains NULL byte
insun解决方案:出错原因是直接是把后缀为xls的execl文件重命名为csv的 正常的要是另存为csv文件 就不会报错了
譬如我们有这么个csv文件:

#!/usr/bin/env python
# -*- coding:utf-8 -*- import csv
with open('egg.csv','rb') as f:
reader = csv.reader(f)
for row in reader:
print row
打印出来是这样的list
['a', '1', '1', '1']
['a', '2', '2', '2']
['b', '3', '3', '3']
['b', '4', '4', '4']
['b', '5', '5', '5']
- 用python写入并生成cs
#!/usr/bin/env python
# -*- coding:utf-8 -*- import csv
with open('egg2.csv', 'wb') as csvfile:
spamwriter = csv.writer(csvfile, delimiter=' ',quotechar='|', quoting=csv.QUOTE_MINIMAL)
spamwriter.writerow(['a', '', '', '', ''])
spamwriter.writerow(['b', '', '', '', ''])
spamwriter.writerow(['c', '', '', '', ''])
spamwriter.writerow(['d', '','','', ''])
spamwriter.writerow(['e', '','','', ''])

这样存进去的是存到一列了 跟我们原本意图存进5列不一样
使用python的csv生成excel所兼容的csv文件的话,主要就是创建writer时的参数时要有dialect=’excel’
代码修改为:
#!/usr/bin/env python
# -*- coding:utf-8 -*- import csv
with open('egg2.csv', 'wb') as csvfile:
spamwriter = csv.writer(csvfile,dialect='excel')
spamwriter.writerow(['a', '', '', '', ''])
spamwriter.writerow(['b', '', '', '', ''])
spamwriter.writerow(['c', '', '', '', ''])
spamwriter.writerow(['d', '','','', ''])
spamwriter.writerow(['e', '','','', ''])
2、利用paramiko与csv结合
#!/usr/bin/python
#coding:utf-8 import paramiko
import csv ssh = paramiko.SSHClient() #创建链接
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #设置第一次登录的yes/no
ssh.connect('192.168.1.108',22,'root','Pwd@1234') #密码登录方式
stdin,stdout,stderr = ssh.exec_command('esxcli network ip interface ipv4 get') #执行的命令
w = stdout.read() #拿到执行的结果 字符串格式
ssh.close() #关闭连接
obj = open('read_test','wb+') #将执行的结果放入文件中保存
obj.write(w)
obj.close() with open('read_test','rb') as txt_file: #打开保存结果的文件
with open('test_excel.csv', 'wb') as excl_file: #打开一个新文件保存
spamwriter = csv.writer(excl_file,dialect='excel') #创建excel格式的文件对象
for line in txt_file.readlines(): #读取结果文件的每一行
re = line.split() #按照空格分割将每行转为列表
spamwriter.writerow(re) #写入到文件当中
结果存入excel表格
python用paramiko将执行的结果存入excel表格的更多相关文章
- python之paramiko 远程执行命令
有时会需要在远程的机器上执行一个命令,并获得其返回结果.对于这种情况,python 可以很容易的实现. 1 .工具 Python paramiko 1) Paramiko模块安装 在Linux的Ter ...
- python 直接存入Excel表格
def write_excels(self, document): outwb = openpyxl.Workbook() outws = outwb.create_sheet(index=0) fo ...
- python工具 - 从文件名读取特定信息到excel表格
情景:文件名中包含学号和用户名,其中用户名在前学好在后,学号为2位,如harry33.txt.natasha12.txt. 要求:将多个文件名中的用户名与学号分开并保存到excle中. 代码部分: i ...
- 将txt文件数据存入excel表格
前言 最近使用Appium自动化在测试设备配网的情况,需要记录每次成功与否和耗时时间. 由于App不是很稳定,执行一段时间会奔溃,因此数据只能通过追加的形式写入到txt文件. 实现过程 存储在txt文 ...
- 使用python读取京东pdf发票信息导出到excel表格中
代码 #!/usr/bin/env python # -*- coding: utf-8 -*- """ pip install pdfminer3k pip insta ...
- 用python批量处理Excel表格,处理结果又快又好,做办公室最靓的那个仔
使用python批量处理Excel数据 让你根据Excel上所有人的身份证号码,提取出公司员工的生日 让你每个月都将公司所有人的考勤数据整理一下 类似这样的格式化的重复操作,你还在每次都使用的 ...
- Python学习总结 06 paramiko 远程执行命令
有时会需要在远程的机器上执行一个命令,并获得其返回结果.对于这种情况,python 可以很容易的实现. 1 工具 Python paramiko 1) Paramiko模块安装 在Linux的Term ...
- Python通过paramiko批量远程主机执行命令
一.前言 在日常运维的过程中,经常需要登录主机去执行一些命令,有时候需要登录一批主机执行相同的命,手动登录执行的化效率太慢, 所以可以通过Python的paramiko模块批量执行,本篇文章基于pyt ...
- 如何进行服务器的批量管理以及python 的paramiko的模块
最近对公司的通道机账号进行改造管理,全面的更加深入的理解了公司账号管理的架构.(注:基本上所有的机器上的ssh不能使用,只有部分机器能够使用.为了安全的角度考虑,安装的不是公版的ssh,而都是定制版的 ...
随机推荐
- VirtualBox 中的UBUNTU和java环境的配置以及各种常用说明
本来是要ubuntu下学习C++的,但是又懒的用高手们推荐的各种记事本级的操作,所以要用IDE.(我用IDE我自豪,人类的进化就是建立在工具的使用这个基础之上的.)我选用了oracle的netbean ...
- 【BZOJ3110】【整体二分+树状数组区间修改/线段树】K大数查询
Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位 ...
- 绑定下拉框时避免触发SelectedIndexChanged事件
在从数据库读取数据集绑定到下拉框时会立即触发其SelectedIndexChanged事件造成异常,可对其SelectedIndexChanged事件采取先解除后附加的方法解决. cmbXl_gt.V ...
- wechat-php-sdk
wechat-php-sdk 微信公众平台php版开发包 支持消息加解密方式的明文模式.兼容模式.安全模式 支持自动接入微信公众平台(步骤) 功能模块 Wechat (处理自动接入.获取与回复微信消息 ...
- Device.js——检测设备平台、操作系统的Javascript 库
http://segmentfault.com/a/1190000000373735 Device.js 是一个可以让你检测设备的平台,操作系统和方向 JavaScript 库,它会自动在 <h ...
- TRECT的使用
作为一张画布,在上面绘制各种图形或显示图像,但在CANVAS的使用过程中少不了一个特殊对象,那就是矩形RECT,灵活使用它会完成很多特殊的功能,为Delphi编制的Windows程序增加活力. REC ...
- Problem:To Connect with MySQL in Virtual PC Environment
I'm trying to build a 1:n dev environment,with the help of Vsever(just like VMware worked on sever) ...
- ipconfig的C语言实现
首先,这篇文章实现了两种方法查询IP,实现截图如下: 第一种方法时调用系统命令,代码如下: #include <cstdlib> #include <iostream> usi ...
- Scut DirCenter 网站编辑、搭建与调试
直接利用 Scut 提供的服务器管理工具进行服务器管理. 教程:https://github.com/ScutGame/Scut/wiki/DirServer. 几个注意点: 下载的数据库导入bat是 ...
- 关于 self 和 super 在oc 中 的疑惑 与 分析
关于 self 和 super 在oc 中 的疑惑 与 分析 面试一定都是很注重 基础的,不管高级还是初级. 虽然基础好跟基础不好都可以写 代码,网上那么多资料. 区分高低也就是研究的深度和广度 ...