- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已经编写了一个正在执行以下操作的 python 脚本;
以上所有内容都保存在日志文件中,一切都正常工作,但我没有从日志文件中得到我想要的内容。
import subprocess
from datetime import datetime
from sys import stderr
logfile="/var/tmp/home-backup.log"
TimeStamp = datetime.now().strftime("%a %d %b %Y %H:%M:%S - ")
BackStamp = datetime.now().strftime("%d-%b-%Y")
Portal = "192.168.1.59:3260"
Target = "iqn.2014-07.com.synology:fabdskst.linux-tgt1.888dddfd71"
File_obj = open(logfile, "a",0)
MyCommand = "sudo iscsiadm -m node --targetname " + Target + " --portal \"" + Portal + "\"" + " --login"
Discover = "sudo iscsiadm -d 0 -m discovery -t sendtargets -p 192.168.1.59:3260"
MyMount = "sudo mount -t ext4 -v /dev/sdc /media/linuxLUN01/"
MyBackup = "tar -cvzf /media/linuxLUN01/Mint_backup_" + BackStamp + ".tgz /home/fabrice/"
File_obj.write(TimeStamp)
subprocess.call(MyCommand, shell=True, stdout=File_obj, stderr=subprocess.PIPE)
File_obj.write(TimeStamp)
subprocess.call(MyMount, shell=True, stdout=File_obj, stderr=subprocess.PIPE)
File_obj.write(TimeStamp)
subprocess.call(MyBackup, shell=True, stdout=File_obj, stderr=subprocess.PIPE)
File_obj.close()
我希望当输出出现在屏幕上时,标准输出中的每一行都带有实时时间戳(在我的例子中,标准输出被重定向到日志文件)。相反,只有命令的第一个输出带有时间戳,其余部分则没有。
我正在学习Python,所以并不是我不好(你可能已经注意到我现在没有做任何测试,稍后会进行)。
我正在考虑如何解决这个问题,但我只是想出了一个不优雅的解决方案,在时间方面并不严格精确;
任何人有其他想法可以使这个更准确吗?理想情况下,我想拦截每个标准输出条目并在其出现时为其添加时间戳。目前备份大约需要 5 分钟。
非常感谢任何建议
根据 Ram 的要求,从日志文件中摘录
Sat 04 Oct 2014 22:15:04 - Logging in to [iface: default, target: iqn.2014-07.com.synology:fabdskst.linux-tgt1.888dddfd71, portal: 192.168.1.59,3260] (multiple)
Login to [iface: default, target: iqn.2014-07.com.synology:fabdskst.linux-tgt1.888dddfd71, portal: 192.168.1.59,3260] successful.
Sat 04 Oct 2014 22:15:04 - Sat 04 Oct 2014 22:15:04 - /home/fabrice/
/home/fabrice/.gnome2_private/
/home/fabrice/.profile
/home/fabrice/.ICEauthority
/home/fabrice/.linuxmint/
/home/fabrice/.linuxmint/mintUpload/
/home/fabrice/.linuxmint/mintUpload/services/
/home/fabrice/Downloads/
/home/fabrice/Downloads/mshell.zip
/home/fabrice/Downloads/bash-4.3.tar.gz
/home/fabrice/Downloads/VMwareTools-9.2.4-1398046.tar.gz
/home/fabrice/Downloads/vmware-tools-distrib/
/home/fabrice/Downloads/vmware-tools-distrib/vmware-install.pl
/home/fabrice/Downloads/vmware-tools-distrib/lib/
/home/fabrice/Downloads/vmware-tools-distrib/lib/lib32/
/home/fabrice/Downloads/vmware-tools-distrib/lib/lib32/libgdkmm-2.4.so.1/
/home/fabrice/Downloads/vmware-tools-distrib/lib/lib32/libgdkmm-2.4.so.1/libgdkmm-2.4.so.1
您可以看到,只有每个命令的输出的第一行带有时间戳
至于stderr=subprocess.PIPE,我使用它没有什么特别的原因,我只是把它放在那里,就像我在网上找到的示例一样,我仍然需要了解它的作用。
最佳答案
不是经过测试的解决方案,但我相信它工作正常:
import subprocess as sub
[...]
with open(logfile, "a", 0) as File_obj:
for cmd in (MyCommand, MyMount, MyBackup):
with sub.Popen(cmd, shell=True, stdout=sub.PIPE, universal_newlines=True) as proc:
while proc.poll() is None:
log = [TimeStamp + line for line in proc.stdout.readlines()]
File_obj.writelines(log)
观察:您希望 stderr 输出到终端,对吗?
关于python - 如何在使用 python 在提示符下发出命令后截取 stdout 的每一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26195502/
我有以下代码来捕获和处理运行命令输出。 如何修改它以便运行命令窗口显示输出并同时记录输出?更换 @SW_HIDE与 @SW_SHOW (或等效的)只显示一个空白的命令窗口。 类似于linux的东西te
[已编辑] 用于处理 subprocess.Popen 标准输出的 2 个选项是 stdout="a_file_name" 和 stdout=subprocess.PIPE。 stderr 可以通过
c99 的 7.19.3/7 节指出: At program start-up, three text streams are predefined and need not be opened ex
我正在运行以下 proc_open 函数。加载页面时,出现错误: Use of undefined constant STDOUT - assumed 'STDOUT'` 如何正确设置STDOUT和S
我有一个运行多个进程的开发堆栈:网络服务器、自动测试、后台编译等。所有这些都是基本的命令行命令,例如 node app.js 或 lein midje :autotest. 是否可以使用一个脚本在“后
我正在使用 SLURM 在 super 计算机上调度作业。我已设置 --output=log.out 选项,将作业标准输出中的内容放入文件 (log.out)。我发现该文件每 30-60 分钟更新一次
ansible/ansible-playbook 版本:2.1.2.0/2.2.0.0 我正在尝试使用 yum/apt 安装软件包,但由于安装软件包的存储库位于 packagecloud.io 中,有
bala@hp:~$ echo "Hello World" > stdout bala@hp:~$ cat stdout Hello World bala@hp:~$ echo "Hello Worl
在从 Fortran 编写的外部库中调用嘈杂的函数之前,我正在使用如下代码重定向标准输出: // copy standard output out = dup(STDOUT_FILENO); // c
这个问题在这里已经有了答案: How can I pipe stderr, and not stdout? (11 个答案) 关闭 6 年前。 我有一个程序,我想检查其 STDERR 输出并在其上运
我正在从 perl 运行一个 java 应用程序 这是脚本 #!/usr/bin/perl use strict; use warnings; $| = 1; my $args = join (" "
我正在尝试将 python 脚本的 STDOUT 重定向到一个文件。 如果 STDOUT 是从 sys 导入的,脚本的输出不会被重定向到一个文件: from sys import stdout std
我正在尝试使用 PHP 和 Apache(在 Docker 的前台运行)写入 stdout(或 stderr)。 这些作品: file_put_contents( "php://stderr","wo
我正在尝试重定向标准输出,以便 Windows 应用程序中的 printf 将转到我选择的文件。 我这样做: outFile = fopen("log.txt", "w"); *stdout = *o
在 Ruby 中,$stdout(前面有一个美元符号)和 STDOUT(全部大写)有什么区别?在进行输出重定向时,应该使用哪个,为什么? $stderr 和 STDERR 也是如此。 编辑: 刚找到一
让我们看看这个Hello World程序 #include int main(int argc, char ** argv) { printf("Hello, World!"); c
我在 64 位机器上运行 Ubuntu 20.04。 我想将 stdout 重定向到从 memfd_create 获得的描述符。似乎使用 memfd_create 创建的匿名文件只有在 stdout
我想在 Python 脚本末尾捕获控制台输出。也就是说,我既想正常打印到控制台,又想在执行结束时将控制台输出保存到文件中。 我看过各种相关的 SO 问题 1 , 2 , 3尽管他们要么简单地重定向输出
我知道可以将两者都重定向到特定文件: ./command 1> out.log 2> err.log 或 ./command 1>test.log 2>&1 将两者写入文件。但是我不知道在只打印其中一
我知道可以将两者都重定向到特定文件: ./command 1> out.log 2> err.log 或 ./command 1>test.log 2>&1 将两者写入文件。但是我不知道在只打印其中一
我是一名优秀的程序员,十分优秀!