我有一段代码可以在服务器上正常工作,而不能在其他服务器( Linux服务器)上工作。
import psycopg2,psycopg2.extras
conn = psycopg2.connect("host=xx.x.x.x dbname=dev user=user password=pass" )
parentId='272'
dbCur = conn.cursor(cursor_factory=psycopg2.extras.NamedTupleCursor)
dbCur.execute('select * from "treeItem" where "parentId" = %s order by "order"',(parentId,))
for row in dbCur:
print type(row)
print row.__dict__
vars(row)
dbCur.close()
conn.close()服务器错误的输出是:
class 'psycopg2.extras.Record'
Traceback (most recent call last):
File "test1.py", line 8, in <module>
print row.__dict__
AttributeError: 'Record' object has no attribute '__dict__'但它可以在另一台服务器上正常工作。相同版本的python (2.7)和psycopg2 2.5
psycopg2.extras.Record类如何在一个环境中而不是在其他环境中拥有__dict__?
编辑
编写python2.7.3和psycopg2 2.5 (dt dec pq3 ext)
不要使用python2.7.5 psycopg2 2.5.1 (dt dec pq3 ext)
发布于 2014-09-22 17:58:02
您使用的是psycopg2.extras.NamedTupleCursor,它生成用等级工厂生成的类的实例。这些类使用__slots__来限制它们的内存使用。
通常,带有__slots__的类没有__dict__属性。但是,在Python2.7.3中添加了一个__dict__属性(参见修订: 26d5f022eb1a),特别是为了支持vars()的使用。后期变化再次从Python2.7.5中删除支持,然后是读取Python 2.7.6。该属性充当代理,调用namedtuple._asdict()生成OrderedDict对象。
您有一个没有属性的Python2.7.x发行版,例如2.7、2.7.1、2.7.2或2.7.5中的一个。您可以通过调用方法来解决这个问题:
for row in dbCur:
print type(row)
print row._asdict()https://stackoverflow.com/questions/25979801
复制相似问题