2013-05-22 128 views
2

我收到此錯誤屬性錯誤:HelloWorld的實例沒有屬性的主

Traceback (most recent call last): 
    File "helloworld.py", line 66, in module 
     hello.main() 
AttributeError: Helloworld instance has no attribute 'main' 

我運行代碼的Linux機器

#!/usr/bin/env python 

# example helloworld.py 
import pygtk 
pygtk.require('2.0') 
import gtk 

class HelloWorld: 

    # This is a callback function. The data arguments are ignored 
    # in this example. More on callbacks below. 
    def hello(self, widget, data=None): 
     print "Hello World" 

    def delete_event(self, widget, event, data=None): 
     # If you return FALSE in the "delete_event" signal handler, 
     # GTK will emit the "destroy" signal. Returning TRUE means 
     # you don't want the window to be destroyed. 
     # This is useful for popping up 'are you sure you want to quit?' 
     # type dialogs. 
     print "delete event occurred" 

     # Change FALSE to TRUE and the main window will not be destroyed 
     # with a "delete_event". 
     return False 

    def destroy(self, widget, data=None): 
     print "destroy signal occurred" 
     gtk.main_quit() 

    def __init__(self): 
     # create a new window 
     self.window = gtk.Window(gtk.WINDOW_TOPLEVEL) 

     # When the window is given the "delete_event" signal (this is given 
     # by the window manager, usually by the "close" option, or on the 
     # titlebar), we ask it to call the delete_event() function 
     # as defined above. The data passed to the callback 
     # function is NULL and is ignored in the callback function. 
     self.window.connect("delete_event", self.delete_event) 

     # Here we connect the "destroy" event to a signal handler. 
     # This event occurs when we call gtk_widget_destroy() on the window, 
     # or if we return FALSE in the "delete_event" callback. 
     self.window.connect("destroy", self.destroy) 

     # Sets the border width of the window. 
     self.window.set_border_width(10) 

     # Creates a new button with the label "Hello World". 
     self.button = gtk.Button("Hello World") 

     # When the button receives the "clicked" signal, it will call the 
     # function hello() passing it None as its argument. The hello() 
     # function is defined above. 
     self.button.connect("clicked", self.hello, None) 

     # This will cause the window to be destroyed by calling 
     # gtk_widget_destroy(window) when "clicked". Again, the destroy 
     # signal could come from here, or the window manager. 
     self.button.connect_object("clicked", gtk.Widget.destroy, self.window) 

     # This packs the button into the window (a GTK container). 
     self.window.add(self.button) 

     # The final step is to display this newly created widget. 
     self.button.show() 

     # and the window 
     self.window.show() 

    def main(self): 
     # All PyGTK applications must have a gtk.main(). Control ends here 
     # and waits for an event to occur (like a key press or mouse event). 
     gtk.main() 

# If the program is run directly or passed as an argument to the python 
# interpreter then create a HelloWorld instance and show it 
if __name__ == "__main__": 
    hello = HelloWorld() 
    hello.main() 

這是一個問題的縮進以下給出?如何解決它? 我試圖搜索互聯網,但沒有幫助。 這是pyGTK教程中給出的相同代碼。 請幫助。

+1

(1)您的錯誤信息與您的代碼不符。你的錯誤信息引用'Helloworld',小寫'w',但你的代碼有'HelloWorld',大寫'W'。錯誤信息說'hello.main()'在66行,但ISTM更接近〜80。你確定你正在運行你認爲你的程序嗎? (2)爲了確保沒有出現混合製表符和空格的問題(對我來說看起來沒問題,但很難確定),使用'python -tt your_program_name.py'運行你的程序。 – DSM

+0

嘿,是的,這不是代碼。其實我從Windows上傳這篇文章,並在Linux中的代碼有點修改(我刪除了一些空格)。在給出正確的縮進之後,代碼在linux中正常工作。歡呼! –

回答

1

我只是將這段代碼複製到我的Linux機器上並運行它,它工作得很好,沒有錯誤。你是從命令行運行的嗎?像$python helloworld.py?還是你想通過Python控制檯會話來運行它?

縮進似乎不成問題。你運行的是什麼版本的Python?

相關問題