Похоже, есть « любимый » звонок, который вы можете сделать, передав ему коллекцию твитов.
Хотя я не могу проверить это в данный момент, что-то вроде этого должно работать:
var tweets = client.search("#Hello_World", result_type: "recent").take(20)
client.favorite(tweets)
Вы могли создать обертку сценария, которая запускает Вашу программу командной строки как подпроцесс, затем добавьте вывод к чему-то как текстовый виджет.
from tkinter import *
import subprocess as sub
p = sub.Popen('./script',stdout=sub.PIPE,stderr=sub.PIPE)
output, errors = p.communicate()
root = Tk()
text = Text(root)
text.pack()
text.insert(END, output)
root.mainloop()
, где сценарий является Вашей программой. Можно, очевидно, распечатать ошибки в другом цвете или чем-то как этот.
Перенаправление stdout к записи () метод, который обновляет Ваш gui, является одним способом пойти, и вероятно самым быстрым - хотя выполняя подпроцесс является, вероятно, более изящное решение.
Только перенаправление stderr, как только Вы действительно уверены, что оно произошло и работа, хотя!
реализация В качестве примера (gui файл и сценарий тестирования):
test_gui.py:
from Tkinter import *
import sys
sys.path.append("/path/to/script/file/directory/")
class App(Frame):
def run_script(self):
sys.stdout = self
## sys.stderr = self
try:
del(sys.modules["test_script"])
except:
## Yeah, it's a real ugly solution...
pass
import test_script
test_script.HelloWorld()
sys.stdout = sys.__stdout__
## sys.stderr = __stderr__
def build_widgets(self):
self.text1 = Text(self)
self.text1.pack(side=TOP)
self.button = Button(self)
self.button["text"] = "Trigger script"
self.button["command"] = self.run_script
self.button.pack(side=TOP)
def write(self, txt):
self.text1.insert(INSERT, txt)
def __init__(self, master=None):
Frame.__init__(self, master)
self.pack()
self.build_widgets()
root = Tk()
app = App(master = root)
app.mainloop()
test_script.py:
print "Hello world!"
def HelloWorld():
print "HelloWorldFromDef!"