- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
规范:Python 2.7
我正在开发一个包含多个模块的项目,我想在所有模块中激活 __future__ 模块的一些功能。我想在一个模块上导入我需要的所有功能,然后将该单个模块导入到每个其他模块,并让这些功能在所有模块中处于事件状态,或者达到那种效果。
我试过:
[A.py]
from __future__ import division
[B.py]
import A
print(1/2)
运行 B.py 除法仍然是整数。我试过:
[A.py]
print(1/2)
[B.py]
from __future__ import division
import A
运行 B.py 给出了相同的结果。对于前面的两个示例,我还尝试将“导入 A”切换为“从 A 导入 *”,结果相同。
我在 Google 上搜索了一段时间,并在 Python 文档中找到了关于 __future__ 模块如何工作的最佳描述,这显然足够了。在那里,我只能找到这些功能将在它们被导入到的模块中处于事件状态的保证,而没有提及如何在全局范围内执行此操作。
所以我想知道是否有办法做到这一点,可以是我描述的方式,也可以是创建某种运行时配置文件,也可以是通过其他方式。
最佳答案
没有办法用语言来做到这一点;从这个意义上说,你真的不能让 __future__
导入全局。 (好吧,你可能可以用围绕 imp
或其他东西的复杂的东西替换普通的 import
语句。请参阅 Future statement 文档并向下滚动到“由...编译的代码”但是类似这样的事情几乎肯定是个坏主意。)
原因是 from __future__ import division
并不是真正的正常导入。或者,更确切地说,它不仅仅是一个正常的导入。实际上,您确实获得了一个名为division
的名称,您可以检查它,但仅仅拥有该值没有任何效果——因此将它传递给其他模块不会影响那些模块。在正常导入之上,Python 具有特殊的魔力,可以检测模块顶部或交互式解释器中的 __future__
导入,并更改代码的编译方式。参见 future对于“真正的进口”部分,Future statements对于“魔法”部分,如果您需要所有详细信息。
并且没有配置文件可以让您执行此操作。但是有一个命令行参数:
python -Qnew main.py
这与在任何地方执行 from __future__ import division
具有相同的效果。
您可以将其添加到 #!
行,或 alias pyfuturediv='python -Qnew'
(甚至 alias python='python -Qnew'
) 在你的 shell 中,或者其他什么,它可能和你的目的的配置文件一样好。
但实际上,如果您想确保模块 B 获得新式划分,您可能应该首先在 B 中声明 __future__
。
或者,当然,您可以只为 Python 3.0+ 而不是 2.3-2.7 编写。 (请注意,一些核心开发人员反对使用命令行参数,因为“全局获取功能 X 的正确方法是使用 Python 版本 >= 功能 X 的 MandatoryRelease”。)或使用 //
当你的意思是 //
时。
另一种可能性是使用 six ,一个旨在让您编写几乎与 Python 3.3 类似的代码并使其在 2.4-2.7(和 3.0-3.2)中正常工作的模块。例如,您没有得到 print
函数,但得到了一个工作完全相同的 print_
函数。您不会获得 Unicode 文字,但会获得 u()
假文字 — 连同源代码中的 UTF-8 编码声明,几乎已经足够好了。它还提供了很多你无法从 __future__
获得的东西——StringIO
和 BytesIO
,exec
作为函数,next
函数等。
如果问题是你有 1000 个源文件,并且编辑它们很痛苦,你可以使用 sed
,或者使用 3to2
修复除法,或者……
关于python - 我们如何才能使 __future__ 进口全局化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13773861/
如果“print”没有被列为方法之一,这样说是否正确 __future__.__dict__.keys() 那么我使用的Python版本不提供 future 的打印功能? (我使用的是 Python
我一直对 __future__ 着迷模块——特别是,它能够改变语句在 python 中的解析方式。 最有趣的是如何做类似的事情 from __future__ import print_functio
在 python 2.7 中,通过使用 from __future__ import division, print_function 我现在可以让 print(1/2) 显示 0.5。 但是是否可
Python doc __future__ 在 python 文档中关于 __future__下表显示了 3.7.0b1 中的“可选”和“4.0 中的强制性”注释 但是我仍然可以在 3.8.2 中使用
这有效:(结果 = 0.01) from __future__ import division def division_test(): print 10/1000 division_test
使用 Cython header 指令和使用 future 导入的正确方法是什么? Python 2.7.x 例子: 1: from __future__ import division 2: #cy
我可以放置: from __future__ import absolute_import 在我的包的顶层目录 __init__.py 中,并保证 absolute_import 将应用于在该包或子包
运行语句时 from __future__ import annotations 我收到以下错误: Traceback (most recent call last): File "/usr/li
我正在为一个目前只有 Python 2 的项目贡献代码,以允许它在 Python 3 上运行。我应该输入以下内容吗: from __future__ import (unicode_literals,
我有错误,因为 No module named __future__。我使用 tensorflow,它有 Python2.7。运行程序后,出现如下所示的错误。 import tensorflow Tr
规范:Python 2.7 我正在开发一个包含多个模块的项目,我想在所有模块中激活 __future__ 模块的一些功能。我想在一个模块上导入我需要的所有功能,然后将该单个模块导入到每个其他模块,并让
我已经回答了有关future 模块如何工作的问题。 What is __future__ in Python used for and how/when to use it, and how it w
我想在 exec 函数中使用 future 模块。但看起来只在当前的 exec 函数中生效,而不会在后面的 exec 调用中生效。以下代码显示了问题。第二个 future 模块生效,您可以看到输出 h
所有类都需要先定义才能用作类型提示。为了在某些情况下解决这个问题,__future__ import is recommended 。这就是为什么以下代码可以正常工作(在 Python 3.7 中
我个人不明白为什么 from __future__ 导入必须在文件的顶部。我要问的是为什么,为什么他们必须在顶部?这是什么原因? 最佳答案 它们可以更改语言语法,包括但不限于 import 语句的行为
我不是专业程序员,所以我的知识有很多漏洞(请注意)。 我在 python 3.7 中编写了一些库。但现在我想从使用 python 2.7 的 3D 应用程序访问它们。他们拥有的唯一真正的 3.7 特定
这是我的应用程序中已有的其他导入 import os import sys from google.appengine.ext.webapp import template import cgi im
我的 python 脚本开始于 from __future__ import division 在 RI 我做 library(rPython) python.load("myscript.py")
在 python 2.x 中,两个整数相除返回一个整数。但是,如果您使用 from ___future___ import division 你可以获得一个浮点值: >>> 3/2 1 >>> fro
我编写了以下 doctest x.doctest: This is something: >>> x = 3 + 4 foo bar something else: >>> from
我是一名优秀的程序员,十分优秀!