我正在尝试编写一个每1分钟读取一次变量的函数,并返回每次的值。变量名是proc:
proc = subprocess.Popen(['sshpass', '-p', password, 'rsync', '-avz', '--info=progress2', source12, destination],
stderr=subprocess.PIPE, stdout=subprocess.PIPE).communicate()[0]
进度存储在proc变量中。我希望函数每1分钟轮询一次变量并返回值。执行此操作直到变量执行为止。最好的方法是什么?
尝试使用:
def doWork():
while True:
proc = subprocess.Popen(['sshpass', '-p', password, 'rsync', '-avz', '--info=progress2', source12, destination],
stderr=subprocess.PIPE, stdout=subprocess.PIPE).communicate()[0]stdout=subprocess.PIPE).communicate()[0]
data = sort(proc)
print data
time.sleep(10)
虽然没有运气!它同时打印整个进度并循环。
答案 0 :(得分:4)
下面的代码将运行rsync并在命令可用时读取命令的任何输出。我使用rsync的--progress选项让它打印出它的进度。进度更新有时以\n
结尾,有时以\r
结尾。所以我读了单个字符,然后通过查找这两个字符中的任何一个来形成每行字符。每当我遇到新的进度线时,我都会将其打印到屏幕上。您可以选择执行任何操作,例如解析完成百分比并显示图形进度条。如果您有兴趣了解如何在终端check this answer out中生成进度条。我给出了一个同步函数和示例输出的示例调用。
<强>码强>
from subprocess import Popen, PIPE
def sync(src, dest, passwd):
cmd = ['sshpass', '-p', passwd, 'rsync', '-avz', '--progress', src, dest]
p = Popen(cmd, stdout=PIPE)
line = ''
while True:
c = p.stdout.read(1)
if not c:
break
if c in ['\n', '\r']:
print 'rsync progress: %s' % line
line = ''
else:
line += c
sync('/path/big.txt', 'myserver:/path/', 'mypassword')
<强>输出强>
rsync progress: sending incremental file list
rsync progress: big.txt
rsync progress:
rsync progress: 32768 0% 0.00kB/s 0:00:00
rsync progress: 65798144 31% 62.72MB/s 0:00:02
rsync progress: 131596288 62% 62.77MB/s 0:00:01
rsync progress: 197427200 94% 62.79MB/s 0:00:00
rsync progress: 209715200 100% 62.80MB/s 0:00:03 (xfer#1, to-check=0/1)
rsync progress:
rsync progress: sent 204032 bytes received 31 bytes 45347.33 bytes/sec
rsync progress: total size is 209715200 speedup is 1027.70