JPype和JayDeBeAPI:AttributeError:'property'对象没有'isBeanAccessor'属性

1 投票
1 回答
6292 浏览
提问于 2025-04-18 18:51

我在尝试通过JDBC连接数据库时,搭建了JPype(JPype1-0.5.5.4)和JayDeBeAPI 0.1.4,这个是在RHEL系统上进行的。我可以成功使用驱动程序连接,

TrgtCnn = jaydebeapi.connect('com.ibm.as400.access.AS400JDBCDriver',
                          ['jdbc:as400://<mask>','<mask>','<mask>'],
                          '/app/as/lib/jdbc/jt400.jar')

但是当我执行SQL时,在JPype中出现了这个错误信息:

TrgtCrs = TrgtCnn.cursor()
TrgtCrs.execute("SELECT * FROM WA6U999S")

---------------------------------------------------------------------------
AttributeError                            Traceback (most recent call last)
<ipython-input-6-5d46ea8c382d> in <module>()
----> 1 TrgtCrs.execute("SELECT * FROM WA6U999S")

/app/as/opt/anaconda/lib/python2.7/site-packages/jaydebeapi/dbapi2.pyc in execute(self, operation, parameters)
    356             parameters = ()
    357         self._close_last()
--> 358         self._prep = self._connection.jconn.prepareStatement(operation)
    359         self._set_stmt_parms(self._prep, parameters)
    360         is_rs = self._prep.execute()

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_jclass.pyc in _getClassFor(javaClass)
     66         return _CLASSES[name]
     67 
---> 68     pyJavaClass = _JavaClass(javaClass)
     69     _CLASSES[name] = pyJavaClass
     70     return pyJavaClass

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_jclass.pyc in __new__(mcs, jc)
    123         elif not jc.isInterface():
    124             bjc = jc.getBaseClass(jc)
--> 125             bases.append(_getClassFor(bjc))
    126 
    127         if _JAVATHROWABLE is not None and jc.isSubclass("java.lang.Throwable"):

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_jclass.pyc in _getClassFor(javaClass)
     66         return _CLASSES[name]
     67 
---> 68     pyJavaClass = _JavaClass(javaClass)
     69     _CLASSES[name] = pyJavaClass
     70     return pyJavaClass

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_jclass.pyc in __new__(mcs, jc)
    166         for i in _CUSTOMIZERS:
    167             if i.canCustomize(name, jc):
--> 168                 i.customize(name, jc, bases, members)
    169 
    170         # remove multiple bases that would cause a MRO problem

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_properties.pyc in customize(self, class_name, jc, bases, members)
     68 
     69         def customize(self, class_name, jc, bases, members) :
---> 70                 accessor_pairs = _extract_accessor_pairs(members)
     71                 for attr_name, (getter, setter) in accessor_pairs.items():
     72                         if attr_name in members:

/app/as/opt/anaconda/lib/python2.7/site-packages/JPype1-0.5.5.4-py2.7-linux-x86_64.egg/jpype/_properties.pyc in _extract_accessor_pairs(members)
     46                         if _is_java_method(members[property_name]):
     47                                 continue
---> 48                 if access == 'get' and member.isBeanAccessor():
     49                         try:
     50                                 pair = accessor_pairs[property_name]

AttributeError: 'property' object has no attribute 'isBeanAccessor'

我不知道从哪里开始解决这个问题,也找不到任何与这个问题相关的信息。

1 个回答

3

这看起来是JPype中的一个bug

我没有AS/400数据库的访问权限,但我手头有一个Oracle XE数据库,我用它来重现这个问题。下面是我使用的Python代码:

#!/usr/bin/python
import jaydebeapi
conn = jaydebeapi.connect('oracle.jdbc.OracleDriver', ['jdbc:oracle:thin:@localhost:1521:XE', 'user', 'password'])
print conn

我找到了一种我认为可以解决这个问题的方法,并已在上面的JPype问题中发布了。这个解决方案是编辑jpype/_properties.py中的_extract_accessor_pairs函数,找到以下代码并把or替换成and

    for name, member in members.items():
            if not (len(name) > _PROPERTY_ACCESSOR_PREFIX_LEN \
                          or _is_java_method(member)):
                    continue
            # rest of loop omitted...

在做了这个修改后,我遇到的错误就消失了。你也可以试试这个解决方案,看看对你是否有效。

撰写回答