我从系统使用datetime获取当前时间并将其存储为字符串(timenow),但是当我通过sshclient_exec_command将其发送到linux中时,会有一些行为差异。
以下是我的代码:
timenow = datetime.datetime.utcnow().strftime("%Y-%m-%d %H:%M:%S")
command = 'date -s %s' %timenow
stdin, stdout, stderr = self._sshclient.exec_command(command, timeout=10)
try:
command = 'date +"%Y-%m-%d %H:%M:%S"'
stdin, stdout, stderr = self._sshclient.exec_command(command, timeout=10)
ip_time_now = stdout.read().decode(encoding='UTF-8').rstrip('\n')
self.logger.debug(" ip=%s timenow=%s ip_time_now=%s",ip, timenow,ip_time_now)
输出
timenow=2016-09-07 20:15:26 ip_time_now=2016-09-07 21:06:24
timenow和ip_time_now都应该与操作
相同如果我用
替换timenow行timenow = datetime.datetime.utcnow().strftime("%H:%M:%S") #passes, but without
setting the year and month
输出
timenow=20:25:49 ip_time_now=2016-09-07 20:25:50 #1 sec diff is ok
注意:执行命令时输出中没有异常
strftime语法的可能解决方案是什么?