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 구문 앞에 값을 할당할 수 있습니다.이런 연결 요구사항에는 일반적으로 컨텍스트 관리자 기능이 사용되는데요. 오라클 라이브러리의 인스턴스도 지원하는 것 같아요.