Да, вы можете делать анонимные блоки PL / SQL. Ваша переменная связывания для выходного параметра имеет неправильный формат. Это должно быть :out
вместо %(out)s
cursor = connection.cursor()
lOutput = cursor.var(cx_Oracle.STRING)
cursor.execute("""
BEGIN
:out := 'N';
END;""",
{'out' : lOutput})
print lOutput
, который производит вывод:
<cx_Oracle.STRING with value 'N'>