-
此外,请为 Python 3 代码库创建一个单独的分支并并行维护这两个版本,除非完成完整迁移
-
下一步应该是找出与 Python 3 兼容的代码库的依赖关系,为此我建议使用以下工具
-
canisepython3:这有助于找出哪些现有依赖项与 python3 兼容
pip install caniusepython3
- pip-tools:当我们进行迁移时,我们可能还担心固定依赖项和子deps,那么 pip-tools 非常方便,请探索一下
pip install pip-tools
-
一旦对依赖项进行排序,然后运行测试用例并找出失败的数量或任何主要问题,记录测试用例失败,这将帮助您在一定程度上估计工作
-
之后,我们需要进行代码的转换,所以我们已经有了一些可用的自动转换工具,比如2to3
pip install future
- 我们可以使用以下命令将代码自动转换为 Python 3
futurize –stage1 mypackage/**/*.py
-
代码自动转换后,运行测试用例并检查失败次数并开始修复它们
-
修复测试用例后,我们可以继续进行功能测试、回归测试和 CI 管道升级
注意 - 在修复功能测试用例时,让 Python 2 和 Python 3 版本的应用程序在两个不同的虚拟环境中运行会很方便,因为这样我们就可以在两个版本之间来回切换并查看行为变化。坚持修复错误
几个陷阱
正如 futurize 库的文档中提到的那样,它的自动转换输出可能并不完全准确,并且它也存在一些问题和错误,因此在合并代码之前审查自动修复对我们来说很重要,所以根据我们的经验,很少有事情可以小心:
-
自动转换最终会在我们可能使用的所有此类情况下添加列表内置函数
dict.iteritems()
,在转换之后它变成list(dict.items())
因为 在 Python 2.7 中iteritems
返回 alist
而在 Python 3 中它返回<class 'dict_items'>
. 但是,这是一个不必要的调用,因为转换为列表需要时间,您仍然可以通过dict.items()
与转换后的列表相同的方式进行迭代 -
Futurize 还可以在您的代码库中添加大量未使用的导入,如果我们不担心向后兼容性,我们可以摆脱它们,但请注意不要删除所有未使用的导入,并在执行之前检查和分析模块
-
如果您可能在 Python 2.7 中使用过 zip 函数,然后尝试将其转换为 dict,那么 futurize 可能会
zip
使用函数调用进行包装,那么在迁移到 Python 3 后大多数情况下list
您将不需要该函数调用list()
all_vals = dict(list(zip(array1, array2))) # Unnecessary list function call
all_vals = dict(zip(array1, array2)) # Correct
-
Python 3 不再支持相对导入。在 Python 2 中使用相对导入的任何代码现在都必须修改以支持绝对导入
-
在 Python2 中,
CSV
文件应该以二进制模式打开。但是,在 Python 3 中,文件将以文本模式打开
常见错误修复
因此,在迁移过程中,我们最终可能会修复一些非常基本的错误,这些错误可能由于 futurize 或 Python 2 和 3 的差异而引入。因此,我列出了我们面临的一些问题,这可能会帮助您快速摆脱这些问题
- 旧的划分在 Python3 中不起作用,我们可以像这样修复这种情况
from past.utils import old_div
x = y / 1000 # Would give unexpected result in Python 3 and existing test case may fail because of this
x = old_div(y, 1000) # This would result as Python 2
- 在所有异常处理情况下,我们最终可能会遇到这个常见错误,其中 Python 2 我们有一个异常类的名为 message 的属性,而 python 3 没有它
# Old case
except Exception as e:
raise CustomError(message=“message: {}”.format(e.message))
# How to fix
except Exception as e:
raise CustomError(message=“message: {}”.format(e))
- 对于相同的异常处理错误,当我们从
e
变量中删除消息属性时,我们可能会遇到以下错误,我们将对e
某些字符串进行 concat 操作,这将导致失败
# Failure case
try:
1/0
except Exception as e:
一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。
二、Python必备开发工具
工具都帮大家整理好了,安装就可直接上手!
三、最新Python学习笔记
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
四、Python视频合集
观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
五、实战案例
纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
六、面试宝典
简历模板
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!