官术网_书友最值得收藏!

Utilizing requirement files and resolving conflicts

As mentioned previously, a requirements file, requirements.txt, can be created to provide a list of packages to install all at once, via pip install -r requirements.txt. The requirements file can specify specific or minimum versions, or simply specify the library name and the latest version will be installed.

It should be noted that files pulled from the requirements file aren't necessarily installed in a particular order. If you require certain packages to be installed prior to others, you will have to take measures to ensure that the installation is sequential, such as having multiple pip install calls.

Requirements files can specify version numbers of packages explicitly. For example, two different modules (m1 and m2) both depend on a third module (m3). The module m1 requires m3 to be at least version 1.5, but m2 requires it to be no later than version 2.0; the current version of m3 is 2.3. In addition, the latest version of m2 (version 1.7) is known to contain a bug.

Hash digests can be used in requirements files to verify downloaded packages to guard against a compromise of the PyPI database or the HTTPS certificate chain. This is actually a good thing, as in 2017 ten Python libraries (https://www.bleepingcomputer.com/news/security/ten-malicious-libraries-found-on-pypi-python-package-index/) uploaded to PyPI were found to be hosting malicious files.

Because PyPI does not perform any security checks or code auditing when packages are uploaded, it is actually very easy to upload malicious software.

主站蜘蛛池模板: 禹城市| 绥宁县| 潍坊市| 米易县| 乌兰察布市| 木兰县| 安康市| 咸宁市| 都兰县| 分宜县| 榆林市| 静宁县| 浮山县| 呼伦贝尔市| 清原| 永康市| 襄城县| 筠连县| 吴堡县| 吴堡县| 牟定县| 得荣县| 蓝田县| 台南县| 屯留县| 广平县| 始兴县| 修文县| 九龙县| 北碚区| 海安县| 额敏县| 临高县| 南靖县| 达拉特旗| 兰西县| 冕宁县| 陈巴尔虎旗| 陇南市| 万盛区| 抚松县|