深入浅析pycharm中 Make available to all projects的含义


Posted in Python onSeptember 15, 2020

一、为什么要进行包管理?

python中的三方包琳琅满目,提供了各种各样的功能,使得我们免于自己去手写很多代码。比如,我们在测试接口的时候,我们用到了request,我们在测试前端页面的时候,我们用到了webdriver的包,移动UI自动化测试我们用到了airtest的包,诸如此类,不胜枚举。于是,我们在“天长地久”的使用过程中,积累的三方包越来越多,具体有多少,大家可以在命令行执行pip list看一下,数量可能超出自己的想象哦。那么现在,领导给你一个任务,让你开发一个项目,开发完之后,部署到公共的服务器上面。对于这个场景的包管理,我认为有不少人是这么做的:先在本地开发完成,然后使用pip freeze >requirements.txt生成依赖包列表文件。然后将代码放到服务器上之后,继续使用pip install -r requirements.txt在服务器上将依赖包安装好。当然,你的代码跑的66的。但是,在这个项目之前,你可能已经做了很多其他的项目,那些项目也有很多当前项目用不到的依赖包,如果不考虑环境隔离,按照上面的方式去做,当前项目的依赖包就不仅仅是当前项目的依赖包了。也就是说你当前的项目可能只需要10个三方包,你可能装了100个,严重浪费了时间和空间。另外,你的A项目使用django 1.8,另外一个B项目使用django 2.1,怎么实现呢?这种情况下,每个应用可能需要各自拥有一套“独立”的Python运行环境。virtualenv就是用来为一个应用创建一套“隔离”的Python运行环境。

综上,包管理要解决的痛点就是:

1、不必要的包的安装,浪费时间

2、项目之间的依赖包隔离

二、怎么做

1、命令行 先安装虚拟环境模块

pip3 install virtualenv # 安装virtualenv

进入项目目录,创建python虚拟环境

cd haima_api

virtualenv --no-site-packages myvenv # myenv是虚拟环境名字,随便取

这样我们就创建好了haima_api项目的虚拟环境,参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来。

激活虚拟环境

source myvenv/bin/activate

激活之后,命令行最前面会加上一个标识。如下。

深入浅析pycharm中 Make available to all projects的含义

这个时候,在命令行下面执行pip install安装后的包就只会安装到刚刚创建的虚拟环境下,只和当前的项目挂钩,与其他项目无关了。

2、使用pycharm

我们开发的时候,更多会使用到pycharm这个ide,新建项目的时候选择虚拟环境即可

深入浅析pycharm中 Make available to all projects的含义

pycharm使用虚拟环境创建项目

inherit global site-packages:勾选上的话代表创建的新项目需要copy一份全局包到虚拟环境。

Make available to all projects:勾选上,表示,当在虚拟环境下安装包的时候,copy一份到全局。

前面文章中一只提到了全局包和虚拟环境里的包,在此解释一下他们的存放位置:

全局包存放在python安装目录下的\Lib\site-packages子目录里。

虚拟环境包安装在关联的项目目录下面的\${虚拟环境名}\Lib\site-packages子目录里

三、项目部署时批量导包

  •  在当前虚拟环境下,通过pip freeze > requirements.txt(名字随意)
  • 在目标服务器上执行,pip install requirements.txt即可

综上,python项目间的包管理就是这么easy,当你要同时开发多个项目的时候,这个是必不可少的。

到此这篇关于深入浅析pycharm中 Make available to all projects的含义的文章就介绍到这了,更多相关pycharm Make available to all projects内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python实现逆波兰计算表达式实例详解
May 06 Python
Python 使用os.remove删除文件夹时报错的解决方法
Jan 13 Python
python常用知识梳理(必看篇)
Mar 23 Python
python3实现抓取网页资源的 N 种方法
May 02 Python
TensorFlow高效读取数据的方法示例
Feb 06 Python
Python高级特性与几种函数的讲解
Mar 08 Python
Python函数基础实例详解【函数嵌套,命名空间,函数对象,闭包函数等】
Mar 30 Python
Python中函数的基本定义与调用及内置函数详解
May 13 Python
如何使用python进行pdf文件分割
Nov 11 Python
Python3实现将一维数组按标准长度分隔为二维数组
Nov 29 Python
python爬取youtube视频的示例代码
Mar 03 Python
python Polars库的使用简介
Apr 21 Python
pycharm-professional-2020.1下载与激活的教程
Sep 21 #Python
有关pycharm登录github时有的时候会报错connection reset的问题
Sep 15 #Python
Pycharm Git 设置方法
Sep 15 #Python
2020版Python学习路线图(附学习资料)
Sep 15 #Python
关于Kotlin中SAM转换的那些事
Sep 15 #Python
Python二元算术运算常用方法解析
Sep 15 #Python
Python实现像awk一样分割字符串
Sep 15 #Python
You might like
PHP Opcache安装和配置方法介绍
2015/05/28 PHP
javascript[js]获取url参数的代码
2007/10/17 Javascript
javascript cookie操作类的实现代码小结附使用方法
2010/06/02 Javascript
kmock javascript 单元测试代码
2011/02/06 Javascript
JS定时刷新页面及跳转页面的方法
2013/07/04 Javascript
JS Date函数整理方便使用
2013/10/23 Javascript
原始XMLHttpRequest方法详情回顾
2013/11/28 Javascript
ext前台接收action传过来的json数据示例
2014/06/17 Javascript
nodejs下打包模块archiver详解
2014/12/03 NodeJs
Jquery中的$.each获取各种返回类型数据的使用方法
2015/05/03 Javascript
javascript中sort() 方法使用详解
2015/08/30 Javascript
使用JavaScript脚本无法直接改变Asp.net中Checkbox控件的Enable属性的解决方法
2015/09/16 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
2015/09/25 Javascript
基于jQuery实现点击列表加载更多效果
2016/05/31 Javascript
ES5 ES6中Array对象去除重复项的方法总结
2017/04/27 Javascript
vue项目中axios使用详解
2018/02/07 Javascript
微信小程序网络封装(简单高效)
2018/08/06 Javascript
深入探讨JavaScript的最基本部分之执行上下文
2019/02/12 Javascript
JavaScript实现的拼图算法分析
2019/02/13 Javascript
基于vue hash模式微信分享#号的解决
2020/09/07 Javascript
js实现拖拽与碰撞检测
2020/09/18 Javascript
vue脚手架项目创建步骤详解
2021/03/02 Vue.js
浅谈Python生成器generator之next和send的运行流程(详解)
2017/05/08 Python
Python使用matplotlib实现绘制自定义图形功能示例
2018/01/18 Python
使用pandas对矢量化数据进行替换处理的方法
2018/04/11 Python
python高阶爬虫实战分析
2018/07/29 Python
Python2和Python3.6环境解决共存问题
2018/11/09 Python
使用python判断你是青少年还是老年人
2018/11/29 Python
python实现多张图片拼接成大图
2019/01/15 Python
如何用C代码给Python写扩展库(Cython)
2019/05/17 Python
Python中字符串String的基本内置函数与过滤字符模块函数的基本用法
2019/05/27 Python
python中数字是否为可变类型
2020/07/08 Python
35款精致的 CSS3 和 HTML5 网页模板 推荐
2012/08/03 HTML / CSS
活动宣传策划方案
2014/05/23 职场文书
机关中层领导干部群众路线教育实践活动个人对照检查材料
2014/09/24 职场文书
单身证明格式样本
2015/06/15 职场文书