class Test(obj):
def __init__(self):
pass
def _is_flag(self):
try:
v_sql="""
Select count(*)
From tablename
"""
push_ctrl_conn=oracle('ETL_TEST')
self.reach_flag=push_ctrl_conn.runsql(v_sql,1)[0][0]
except Exception,e:
self._set_scan_state('22', str(e))
finally:
push_ctrl_conn.close()
def run(self):
self._is_flag()
if name == '__main__':
test_case=Test()
test_case.run()
类似这种格式,然后就报了
UnboundLocalError: local variable 'push_ctrl_conn' referenced before assignment
try 構文ブロックは実行されない可能性があります。つまり、
push_ctrl_conn
に値が割り当てられない可能性があります。非常によくある間違いですが、一般に、try 構文の前に値を割り当てることができます。この種の接続要件には、Oracle ライブラリのインスタンスもサポートしているコンテキスト マネージャー機能が一般的に使用されると思います。