- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
精简版
我有一段正在调试的代码会检查 __debug__
的值并在它为 True 时执行一些代码。
if __debug__:
<stuff happens>
问题是“事情”永远不会发生,即使 __debug__
看起来是真的。
长版/详细信息
为了检查这一点,我使用以下模式在函数执行时将几个变量(最显着的 __debug__
)的值打印到一个文件中。 (我正在使用 os.open
因为 open
已经在这个模块中定义了。)
try:
myfile = os.open("test.txt", os.O_RDWR|os.O_CREAT|os.O_APPEND)
# work + some print statements to check the value of __DEBUG__
finally:
os.close(myfile)
我最困惑的一段代码是这样的:
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, __debug__))
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, type(__debug__)))
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, bool(__debug__)))
if __debug__:
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, __debug__))
if bool(__debug__):
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, __debug__))
if True:
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, __debug__))
if __debug__:
os.write(myfile, "LINE %s | LDAP FUNCTION __DEBUG__: %s \n" %(sys._getframe(0).f_lineno, __debug__))
输出文件如下所示:
LINE 82 | LDAP FUNCTION __DEBUG__: True
LINE 83 | LDAP FUNCTION __DEBUG__: <type 'bool'>
LINE 84 | LDAP FUNCTION __DEBUG__: True
LINE 88 | LDAP FUNCTION __DEBUG__: True
LINE 90 | LDAP FUNCTION __DEBUG__: True
前 3 个语句(第 82-84 行)是我能想到的检查 __debug__
是否“真实”的所有方式,所有 3 个语句都暗示 __debug__
为真.同样,将 __debug__
转换为 bool 值然后计算 if
(第 88 行)也按预期工作。第 90 行是一个愚蠢的完整性检查。
我在 __debug__
的工作方式中是否遗漏了什么可能导致此问题的原因?
注意:我在处理 python-ldap
模块中的 _ldap_function_call
函数时遇到的错误时发现了这一点。我只在使用 IIS 时遇到此错误 - 在 Django 的开发服务器上一切正常。
最佳答案
如果您重新绑定(bind) __debug__
,它可能会导致完全像这样的症状。
这是因为 __debug__
有点神奇。在模块编译期间,处理文字的相同代码还处理魔法常量 ...
、None
、True
、False
和 __debug__
。 (例如,参见 expr_constant
。)
如果您在代码上运行 dis
以转储字节码,您会看到 if __debug__:
语句要么被完全删除,要么使用 LOAD_CONST
加载编译时 debug
常量,而 if bool(__debug__):
语句使用 LOAD_GLOBAL
加载 __调试__
。
当然这些保证是相同的......除非你重新绑定(bind)__debug__
。在 2.3 左右的某个地方,只写 __debug__ = False
就变得非法了。在 2.7 和 3.0 中,绑定(bind) 任何 名为 __debug__
的属性都是非法的,这意味着你不能再做类似 sys.modules[__name__].__debug__ =错误
。但是您仍然可以这样做,例如 globals()['__debug__'] = False
。
无论哪种方式,你都会得到相同的效果:
if __debug__:
print "debug"
if bool(__debug__):
print "bool"
import sys
sys.modules[__name__].__debug__ = False
if __debug__:
print "debug2"
if bool(__debug__):
print "bool2"
打印出来:
debug
bool
debug2
对于使用 python -O
运行时将其设置为 True 的代码也是如此。
关于python - 尽管 __debug__ 为真,但条件 __debug__ 语句未执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15305688/
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Why can't Python handle true/false values as I expect?
我是不是遗漏了什么或者这是 ruby 中的错误? a = %w(foo bar baz) a.include? "foo" # => true a.size == 3
从 Modelica 文档来看,注释 Evaluate 似乎只对参数有影响: https://build.openmodelica.org/Documentation/ModelicaReferenc
为了避免嵌套的 if 语句并提高可读性,我想创建一个switch(true){ ... } Coldfusion 中的声明。我在 php 中经常使用这个,但是当我在 Coldfusion 中尝试这个时
嗨,我正在尝试处理 ajax json 响应 这是我的代码 success: function (j) { switch(true) { case (j.cho
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
这个问题在这里已经有了答案: How can I return pivot table output in MySQL? (10 个答案) 关闭 5 年前。 我正在尝试构建一个以唯一列值作为列名的表
我制作了一个简单的 JDialog,其中包含一个标签和一个按钮,它基本上相当于信息对话框。所以在对话框中,有一个方法 display() 我在其中调用了 setVisible(true) 五次。 据我
在 bash 4.2.8(1)-release (x86_64-pc-linux-gnu) 在 Ubuntu 11.04 上这个命令 [ $(wc -l /var/www/some.log|cut -
我正在使用 c 语言进行并发处理,我有一个进程池。为此,我让每个 child 都在一个 While (True) 循环中。为了杀死 child ,我正在使用一个全局变量和一个信号处理程序来修改它来打破
我正在尝试选择填写了字段的数据库条目。数据库有两种插入数据的方式,一种输入评论,一种不输入,我希望只选择填写了评论的行。 $requete = "SELECT * FROM daysoff WHER
如何在 JavaMail session 中setDebug(true) 捕获流并在我的日志记录框架中使用它? (缺少下载源代码,更改接受流作为参数的方法,重新编译它,...) 更一般地说,Java
我是 JavaScript 的新手,我刚刚发现了我无法理解的奇怪行为: var magicVar = Math.sin; magicVar == true; // it returns false m
对此感到困惑。 在两台服务器上运行相同版本的 MySQL。 (从完全相同的 rpm 构建)- 沿线的某个地方,一些开发人员改变了一些东西...... 服务器 1: mysql> select ( no
我在查看 OpenSSL 中使用的一些预处理器宏时,从 crypto/stack/safestack.h 中发现了以下内容: #define CHECKED_STACK_OF(type, p) \
所以我遇到了一个问题,我的正则表达式看起来像这样:/true|false/。 当我检查单词 falsee 时,我从这个正则表达式中得到一个 true,有没有办法将它限制为确切的 true 或 fals
我正在对这个恶意 JavaScript 行进行一些试验:var undefined = true; JavaScript 中每个未初始化的变量都有 undefined 的值,这只是一个保存特殊值 'u
我想将 PHP 的微时间存储为我在 MySQL 中的时间戳。 我去过told最好用 DECIMAL 存储它,但我找不到理想的大小。 有谁知道 microtime(true) 返回的最大大小是多少,所以
在 PHP 中,当您在 URL 中包含诸如“var=true”之类的内容时,URL 中的“true”和“false”是否被转换为 boolean 变量,或者它们是否等于文本“true”还是“假”?例如
我是一名优秀的程序员,十分优秀!