https://blog.csdn.net/kenkywu/article/details/6743520
程序代码
class Person:
#constructor
def __init__(self,name,sex):
self.Name = name
self.Sex = sex
def ToString(self):
return 'Name:'+self.Name+',Sex:'+self.Sex
在IDLE中报错:
>>> import Person
>>> per = Person('dnawo','man')
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
per = Person('dnawo','man')
TypeError: 'module' object is not callable
原因分析:
Python导入模块的方法有两种:import module 和 from module import,区别是前者所有导入的东西使用时需加上模块名的限定,而后者不要。
正确的代码:
>>> import Person
>>> person = Person.Person('dnawo','man')
>>> print person.Name
或
>>> from Person import *
>>> person = Person('dnawo','man')
>>> print person.Name
=============下面这个解法更能体现问题所在,就是模块的路径问题
问题:
我不能确定我为什么得到这个错误:
************************************************** **************Traceback (most recent call last): File "my.py" , line 3 , in ? urlparse( 'http://www.cwi.nl:80/%7Eguido/Python.html') TypeError: 'module' object is not callable **************************************************
源代码如下:
import urlparse urlparse( 'http://www.cwi.nl:80/%7Eguido/Python.html')
答复:
"TypeError: 'module' object is not callable"这个信息是说你试图把"urlparse"这个模块作为一个函数来调用,但它却无法调用。
urlparse这个模块包含urlparse 和 urlsplit等函数。我把urlsplit也拖了进来,它的名字和模块名不同。这个可能能帮助你发现问题。以下是调用它们的两种方法。
(1)
>>> import urlparse >>> urlparse.urlparse( 'http://www.cwi.nl:80/%7Eguido/Python.html') ( 'http' , 'www.cwi.nl:80' , '/%7Eguido/Python.html', '' , '' , '' ) >>> urlparse.urlsplit( 'http://www.cwi.nl:80/%7Eguido/Python.html') ( 'http' , 'www.cwi.nl:80' , '/%7Eguido/Python.html', '' , '' ) >>>
(2)
>>> from urlparse import urlparse, urlsplit >>> urlparse( 'http://www.cwi.nl:80/%7Eguido/Python.html') ( 'http' , 'www.cwi.nl:80' , '/%7Eguido/Python.html', '' , '' , '' ) >>> urlsplit( 'http://www.cwi.nl:80/%7Eguido/Python.html') ( 'http' , 'www.cwi.nl:80' , '/%7Eguido/Python.html', '' , '' ) >>>
方法1可能更适合你。
————————————————
版权声明:本文为CSDN博主「走在路上的WWB」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/kenkywu/article/details/6743520