0

我正在玩坐在我的 Raspberry Pi 上的 Telegram 机器人,一切正常,但我试图用命令 /uptime 显示 rpi 的正常运行时间,但没有成功,我尝试了:

elif command == '/uptime':
   bot.sendMessage(chat_id, os.system("uptime"))

或与

elif command == '/uptime':
  uptime = os.system("uptime")
  bot.sendMessage(chat_id,'%s' % uptime )

这是我最后一次不成功的尝试:

elif command == '/uptime':
   uptime = os.popen("awk '{print $1}' /proc/uptime").readline()
   bot.sendMessage(chat_id, ('uptime(sec) = '+uptime))

错误在哪里?

这是完整的代码:

import sys
import os
import telepot
import datetime
import time
from datetime import timedelta

id_a = [111111,2222222,3333333,4444444,5555555]

def handle(msg):
    chat_id = msg['chat']['id']
    command = msg['text']
    sender = msg['from']['id']


    print 'Got command: %s' % command

    if sender in id_a:
     if command == '/ciao':
            bot.sendMessage(chat_id, 'Hei, ciao!')
     elif command == '/apri':
         os.system("sudo python /home/pi/tg/xyz.py")
         bot.sendMessage(chat_id, 'Ti ho aperto!')
    elif command == '/uptime':
       with open('/proc/uptime', 'r') as f:
        usec = float(f.readline().split()[0])
        usec_str = str(timedelta(seconds = usec))
        bot.sendMessage(chat_id, '%s' % usec_str)
    elif command == '/riavvia':
            bot.sendMessage(chat_id, 'Rebooting...')
            os.system("sudo reboot")
    else:
       bot.sendMessage(chat_id, 'Forbidden access!')
       bot.sendMessage(chat_id, sender)

bot = telepot.Bot('myToken')
bot.message_loop(handle)
print 'I am listening ...'

while 1:
    time.sleep(10)
4

2 回答 2

1

您需要从subprocess. 这是因为在其他情况下,Python 会转换stdout. 获取正常运行时间的代码应该是这样的:

import subprocess    
direct_output = subprocess.check_output('uptime', shell=True)

这将为您提供direct_output变量的正常运行时间。

于 2016-12-19T11:20:28.677 回答
0

尝试...

from datetime import timedelta

with open('/proc/uptime', 'r') as f:
    usec = float(f.readline().split()[0])
    usec_str = str(timedelta(seconds = usec))
    # and send message usec_str
于 2016-12-15T00:06:43.387 回答