【问题标题】:Execution of a python script and save the output as a CSV file执行 python 脚本并将输出保存为 CSV 文件
【发布时间】:2017-05-09 13:30:36
【问题描述】:

我想将 python 脚本 (sshClient.py) 的输出保存为 CSV 文件。你能帮我怎么做吗?提前致谢。我在这里分享的代码和结果输出是为了让您更好地理解。

import sys
import time
import select
import paramiko

host = '169.254.115.1'
i = 1

#
# Try to connect to the host.
# Retry a few times if it fails.
#
while True:
    print ('Trying to connect to %s (%i/3)' % (host, i))

    try:
        ssh = paramiko.SSHClient()
        ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
        ssh.connect(host, port=22, username='user', password='user')
        print ("Connected to %s" % host)
        break
    except paramiko.AuthenticationException:
        print ("Authentication failed when connecting to %s") % host
        sys.exit(1)
    except:
        print ("Could not SSH to %s, waiting for it to start" % host)
        i += 1
        time.sleep(2)

    # If we could not connect within time limit
    if i == 3:
        print ("Could not connect to %s. Giving up") % host
        sys.exit(1)

# Send the command (non-blocking)
stdin, stdout, stderr = ssh.exec_command("cd /opt/cohda/test; sudo ./runtest_iperf_tx.sh")

# Wait for the command to terminate
while not stdout.channel.exit_status_ready():
    # Only print data if there is data to read in the channel
    if stdout.channel.recv_ready():
        rl, wl, xl = select.select([stdout.channel], [], [], 0.0)
        if len(rl) > 0:
            # Print data from stdout
            print (stdout.channel.recv(1024)),
#
# Disconnect from the host
#
print ("Command done, closing SSH connection")
ssh.close()

结果输出:Throughput Vs Time

【问题讨论】:

  • 您可以将(stdout.channel.recv(1024)) 写入文件(以二进制模式打开)而不是打印。
  • 您能否编辑我的代码以显示示例?
  • 你能把你得到的输出的几行作为文本而不是像你做的图像那样发布。
  • 我真的很抱歉..由于我现在没有设备,所以现在无法为您提供..

标签: python csv ssh paramiko


【解决方案1】:

未测试,但如果数据是 ascii 的话,这种效果应该可以工作......

# Wait for the command to terminate
csv_str = ""
while not stdout.channel.exit_status_ready():
    # Only print data if there is data to read in the channel
    if stdout.channel.recv_ready():
        rl, wl, xl = select.select([stdout.channel], [], [], 0.0)
        if len(rl) > 0:
            # Print data from stdout
            print (stdout.channel.recv(1024)),
            csv_str += str.split(str(stdout.channel.recv(1024)),",")
#
# Disconnect from the host
#
PathFileName = "/hard/path/filename.csv"
f = open(PathFileName,'a')
f.write(csv_str)
f.close()

【讨论】:

  • 感谢您的回复。需要定义“addrStr”,因为它表示未解析的引用。这种情况我该怎么办?
  • 只是一个愚蠢的问题。如果我没记错,那么您使用命令 PathFileName = "/hard/path/filename.csv" 将文件保存在特定位置..对吗?
  • 是的,它只是一个变量,表示路径和文件的字符串,也可以直接插入到open()函数中。
猜你喜欢
  • 2014-03-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-15
  • 1970-01-01
相关资源
最近更新 更多