linux 移除python_「编程开发」Python实战手记(1)

5aac30054bfd925d5acf27a391c719bb.png

代码迁移

之前编写的时候还运行的很好,现在怎么突然就不能运行了?

在我电脑上运行的很好,换了电脑怎么就不能运行了?

开发软件不能只顾写代码,更要确保代码可以迁移,易于部署,易于维护。

代码都需要依赖特定的环境才能运行。这个环境包括:

  • 你的硬件有没有变化?网络断了吗?显卡换了吗?芯片是intel的还是AMD的?内存有没有变多或变少?...
  • 你的操作系统是Windows10?还是Windows7?还是MacOS?还是Ubuntu(Linux)?还是CentOS(Linux)?...
  • 你的Python版本是2.7?还是3.1?还是3.7?还是4.8?...
  • 你用的第三方库的版本是不是一样?你用的TensorFlow是1.4还是1.7?你用的Numpy是1.1还是2.8?...

如果你的代码突然不能运行了,那么上面这些事情都需要检查一番。你要尽力保证所有环境都没变,否则你的代码就很可能无法正常运行。

让环境适应代码比让代码适应环境容易得多,如果条件允许的话。

为代码单独安装一个老版本的TensorFlow并不麻烦,但要阅读新版本TensorFlow全部的更新说明文档,然后再逐行检查代码符合这些繁文缛节的变化,往往就会要了你的命。最好的建议是,不要冒险,不要冒险,不要冒险!

版本管理

不止是管理自己代码的版本,更要管理第三方依赖库的版本。

最好的办法是将代码及其依赖的整个环境打包到一起。是的,最好把操作系统也打包到一起,部署的时候直接连操作系统一起装。这不是玩笑,Docker容器化部署就是这个思路,而Unikernel(LibOS)模式则更加彻底。

比较轻量化的方法是将所依赖的环境配置记录到文件,迁移到其他设备上之后再依赖配置文件重新建造和原来一样的环境。这样的优点是不必把整个庞大的环境(系统+第三方依赖)都塞进项目中,缺点是每次都需要重建,这个重建过程往往不仅耗时而且不很可靠。

Pipenv工具属于后者,早期比较流行的Virtualenv工具已经被其取代。它的基本流程是:

  1. 创建项目文件夹,配置相应的项目管理,如Git和Github,参见下面项目管理。
  2. 使用pipenv install初始化,自动创建配置文件Pipfile和Pipfile.lock。如果已经存在配置文件,它将根据配置文件重建环境。
  3. 如果你要使用特定Python版本初始化项目,可以用pipenv install --python 3.6命令。
  4. 把配置文件中第三方库的安装源地址替换为国内镜像,如阿里url = "https://mirrors.aliyun.com/pypi/simple"。
  5. 项目中使用的所有第三方依赖都要使用pipenv install xxx安装,这样才能确保安装记录被正确写入配置文件。如果你需要移除某个依赖,可以使用命令pipenv uninstall xxx命令。
  6. 运行项目文件要使用pipenv run python xxx.py。或者使用pipenv shell进入项目环境再python xxx.py,退出环境的命令是exit或ctrl+D。

项目管理

这里再啰嗦一些内容,补充或强调。

  1. 安装Python的时候一定要确保路径Path被正确添加到系统中,在Windows里就是安装的时候勾选Add Path...选项。
  2. 下载和安装Git软件。
  3. 为Git设定你的用户名和邮箱,git config --global user.name "zhyuzh"和git config --global user.email "zhyuzh3d@hotmail.com"。
  4. 创建项目文件夹,建个README.md文件,随便写点什么。
  5. 如果你需要把远程Github的项目复制到本地,使用git clone https://username:password@github.com/yourname/myproject.git,如果是公开项目可以省略username和password。
  6. 命令行进入项目文件夹,使用git init初始化Git,其实就是建立一个隐身的.git文件夹。
  7. 你最好建一个.gitignore文件,把不需要Git管理的目录加进去,比如不想公开的密码文件secret.py,或者程序临时生成的日志文件夹log/等。
  8. 注册和登录Github网站,新建一个完全空白的项目比如myproject。
  9. 使用你从Github获得的命令建立远程关联,比如git remote add origin https://username:password@github.com/yourname/myproject.git
  10. 如果你搞错了可以git remote remove origin删除关联再来。
  11. 修改项目代码或内容之后,git add .扫描所有文件,git commit -m "xxx"提交到Git。
  12. 同步本地Git到Github项目git push origin master。
  13. 把远程的项目拉取到本地的命令git pull origin master。

画成一张图是这样的:

620112d4cc55e8e71a88b9fe886d3d9f.png

【更多文章请点这里阅读】


每个人的智能时代

如果您发现文章错误,请不吝留言指正;

如果您觉得有用,请点喜欢;

如果您觉得很有用,欢迎转发~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值