日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)Python教程:venv—-創(chuàng)建虛擬環(huán)境

venv —- 創(chuàng)建虛擬環(huán)境

3.3 新版功能.

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),富裕企業(yè)網(wǎng)站建設(shè),富裕品牌網(wǎng)站建設(shè),網(wǎng)站定制,富裕網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,富裕網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

源碼: Lib/venv/


The venv module supports creating lightweight “virtual environments”, each with their own independent set of python packages installed in their site directories. A virtual environment is created on top of an existing Python installation, known as the virtual environment’s “base” Python, and may optionally be isolated from the packages in the base environment, so only those explicitly installed in the virtual environment are available.

When used from within a virtual environment, common installation tools such as pip will install Python packages into a virtual environment without needing to be told to do so explicitly.

See PEP 405 for more background on Python virtual environments.

參見

Python 打包用戶指南:創(chuàng)建和使用虛擬環(huán)境

Availability: not Emscripten, not WASI.

This module does not work or is not available on WebAssembly platforms wasm32-emscripten and wasm32-wasi. See WebAssembly platforms for more information.

創(chuàng)建虛擬環(huán)境

通過執(zhí)行 venv 指令來創(chuàng)建一個 虛擬環(huán)境:

 
 
 
 
  1. Python3 -m venv /path/to/new/virtual/environment

運(yùn)行此命令將創(chuàng)建目標(biāo)目錄(父目錄若不存在也將創(chuàng)建),并放置一個 pyvenv.cfg 文件在其中,文件中有一個 home 鍵,它的值指向運(yùn)行此命令的 Python 安裝(目標(biāo)目錄的常用名稱是 .venv)。它還會創(chuàng)建一個 bin 子目錄(在 Windows 上是 Scripts),其中包含 Python 二進(jìn)制文件的副本或符號鏈接(視創(chuàng)建環(huán)境時使用的平臺或參數(shù)而定)。它還會創(chuàng)建一個(初始為空的) lib/pythonX.Y/site-packages 子目錄(在 Windows 上是 Lib\site-packages)。如果指定了一個現(xiàn)有的目錄,這個目錄就將被重新使用。

3.6 版后已移除: pyvenv was the recommended tool for creating virtual environments for Python 3.3 and 3.4, and is deprecated in Python 3.6.

在 3.5 版更改: 現(xiàn)在推薦使用 venv 來創(chuàng)建虛擬環(huán)境。

在 Windows 上,調(diào)用 venv 命令如下:

 
 
 
 
  1. c:\>c:\Python35\python -m venv c:\path\to\myenv

或者,如果已經(jīng)為 Python 安裝 配置好 PATHPATHEXT 變量:

 
 
 
 
  1. c:\>python -m venv c:\path\to\myenv

本命令如果以 -h 參數(shù)運(yùn)行,將顯示可用的選項(xiàng):

 
 
 
 
  1. usage: venv [-h] [--system-site-packages] [--symlinks | --copies] [--clear]
  2. [--upgrade] [--without-pip] [--prompt PROMPT] [--upgrade-deps]
  3. ENV_DIR [ENV_DIR ...]
  4. Creates virtual Python environments in one or more target directories.
  5. positional arguments:
  6. ENV_DIR A directory to create the environment in.
  7. optional arguments:
  8. -h, --help show this help message and exit
  9. --system-site-packages
  10. Give the virtual environment access to the system
  11. site-packages dir.
  12. --symlinks Try to use symlinks rather than copies, when symlinks
  13. are not the default for the platform.
  14. --copies Try to use copies rather than symlinks, even when
  15. symlinks are the default for the platform.
  16. --clear Delete the contents of the environment directory if it
  17. already exists, before environment creation.
  18. --upgrade Upgrade the environment directory to use this version
  19. of Python, assuming Python has been upgraded in-place.
  20. --without-pip Skips installing or upgrading pip in the virtual
  21. environment (pip is bootstrapped by default)
  22. --prompt PROMPT Provides an alternative prompt prefix for this
  23. environment.
  24. --upgrade-deps Upgrade core dependencies: pip setuptools to the
  25. latest version in PyPI
  26. Once an environment has been created, you may wish to activate it, e.g. by
  27. sourcing an activate script in its bin directory.

在 3.9 版更改: 添加 --upgrade-deps 選項(xiàng),用于將 pip + setuptools 升級到 PyPI 上的最新版本

在 3.4 版更改: 默認(rèn)安裝 pip,并添加 --without-pip--copies 選項(xiàng)

在 3.4 版更改: 在早期版本中,如果目標(biāo)目錄已存在,將引發(fā)錯誤,除非使用了 --clear--upgrade 選項(xiàng)。

備注

雖然 Windows 支持符號鏈接,但不推薦使用它們。特別注意,在文件資源管理器中雙擊 python.exe 將立即解析符號鏈接,并忽略虛擬環(huán)境。

備注

在 Microsoft Windows 上,為了啟用 Activate.ps1 腳本,可能需要修改用戶的執(zhí)行策略??梢赃\(yùn)行以下 PowerShell 命令來執(zhí)行此操作:

PS C:> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

參閱 About Execution Policies 以獲取更多信息。

生成的 pyvenv.cfg 文件還包括 include-system-site-packages 鍵,如果運(yùn)行 venv 時帶有 --system-site-packages 選項(xiàng),則鍵值為 true,否則為 false。

除非采用 --without-pip 選項(xiàng),否則將會調(diào)用 ensurepip 將 pip 引導(dǎo)到虛擬環(huán)境中。

可以向 venv 傳入多個路徑,此時將根據(jù)給定的選項(xiàng),在所給的每個路徑上創(chuàng)建相同的虛擬環(huán)境。

How venvs work

When a Python interpreter is running from a virtual environment, sys.prefix and sys.exec_prefix point to the directories of the virtual environment, whereas sys.base_prefix and sys.base_exec_prefix point to those of the base Python used to create the environment. It is sufficient to check sys.prefix == sys.base_prefix to determine if the current interpreter is running from a virtual environment.

A virtual environment may be “activated” using a script in its binary directory (bin on POSIX; Scripts on Windows). This will prepend that directory to your PATH, so that running !python will invoke the environment’s Python interpreter and you can run installed scripts without having to use their full path. The invocation of the activation script is platform-specific (** must be replaced by the path to the directory containing the virtual environment):

平臺

Shell

用于激活虛擬環(huán)境的命令

POSIX

bash/zsh

$ source /bin/activate

fish

$ source /bin/activate.fish

csh/tcsh

$ source /bin/activate.csh

PowerShell

$ /bin/Activate.ps1

Windows

cmd.exe

C:\> \Scripts\activate.bat

PowerShell

PS C:\> \Scripts\Activate.ps1

3.4 新版功能: !fish and !csh activation scripts.

3.8 新版功能: 在 POSIX 上安裝 PowerShell 激活腳本,以支持 PowerShell Core。

You don’t specifically need to activate a virtual environment, as you can just specify the full path to that environment’s Python interpreter when invoking Python. Furthermore, all scripts installed in the environment should be runnable without activating it.

In order to achieve this, scripts installed into virtual environments have a “shebang” line which points to the environment’s Python interpreter, i.e. #!/**/bin/python. This means that the script will run with that interpreter regardless of the value of PATH. On Windows, “shebang” line processing is supported if you have the 適用于Windows的Python啟動器 installed. Thus, double-clicking an installed script in a Windows Explorer window should run it with the correct interpreter without the environment needing to be activated or on the PATH.

When a virtual environment has been activated, the VIRTUAL_ENV environment variable is set to the path of the environment. Since explicitly activating a virtual environment is not required to use it, VIRTUAL_ENV cannot be relied upon to determine whether a virtual environment is being used.

警告

Because scripts installed in environments should not expect the environment to be activated, their shebang lines contain the absolute paths to their environment’s interpreters. Because of this, environments are inherently non-portable, in the general case. You should always have a simple means of recreating an environment (for example, if you have a requirements file requirements.txt, you can invoke pip install -r requirements.txt using the environment’s pip to install all of the packages needed by the environment). If for any reason you need to move the environment to a new location, you should recreate it at the desired location and delete the one at the old location. If you move an environment because you moved a parent directory of it, you should recreate the environment in its new location. Otherwise, software installed into the environment may not work as expected.

You can deactivate a virtual environment by typing deactivate in your shell. The exact mechanism is platform-specific and is an internal implementation detail (typically, a script or shell function will be used).

API

上述的高級方法使用了一個簡單的 API,該 API 提供了一種機(jī)制,第三方虛擬環(huán)境創(chuàng)建者可以根據(jù)其需求自定義環(huán)境創(chuàng)建過程,該 API 為 EnvBuilder 類。

class venv.EnvBuilder(system_site_packages=False, clear=False, symlinks=False, upgrade=False, with_pip=False, prompt=None, upgrade_deps=False)

EnvBuilder 類在實(shí)例化時接受以下關(guān)鍵字參數(shù):

  • system_site_packages — 一個布爾值,要求系統(tǒng) Python 的 site-packages 對環(huán)境可用(默認(rèn)為 False)。

  • clear — 一個布爾值,如果為 true,則在創(chuàng)建環(huán)境前將刪除目標(biāo)目錄的現(xiàn)有內(nèi)容。

  • symlinks — 一個布爾值,指示是否嘗試符號鏈接 Python 二進(jìn)制文件,而不是進(jìn)行復(fù)制。

  • upgrade — 一個布爾值,如果為 true,則將使用當(dāng)前運(yùn)行的 Python 去升級一個現(xiàn)有的環(huán)境,這主要在原位置的 Python 更新后使用(默認(rèn)為 False)。

  • with_pip — 一個布爾值,如果為 true,則確保在虛擬環(huán)境中已安裝 pip。這使用的是帶有 --default-pip 選項(xiàng)的 ensurepip。

  • prompt — 激活虛擬環(huán)境后顯示的提示符(默認(rèn)為 None,表示使用環(huán)境所在的目錄名稱)。如果使用了 "." 這一特殊字符串,則使用當(dāng)前目錄的基本名稱作為提示符。

  • upgrade_deps — 將基本 venv 模塊更新為 PyPI 上的最新版本。

在 3.4 版更改: 添加 with_pip 參數(shù)

3.6 新版功能: 添加 prompt 參數(shù)

3.9 新版功能: 添加 upgrade_deps 參數(shù)

第三方虛擬環(huán)境工具的創(chuàng)建者可以自由地將此處提供的 EnvBuilder 類作為基類。

返回的 env-builder 是一個對象,包含一個 create 方法:

  • create(env_dir)

    指定要建立虛擬環(huán)境的目標(biāo)目錄(絕對路徑或相對于當(dāng)前路徑)來創(chuàng)建虛擬環(huán)境。create 方法將在指定目錄中創(chuàng)建環(huán)境,或者引發(fā)對應(yīng)的異常。

    EnvBuilder 類的 create 方法定義了可用于定制子類的鉤子:

       
       
       
       
    1. def create(self, env_dir):
    2. """
    3. Create a virtualized Python environment in a directory.
    4. env_dir is the target directory to create an environment in.
    5. """
    6. env_dir = os.path.abspath(env_dir)
    7. context = self.ensure_directories(env_dir)
    8. self.create_configuration(context)
    9. self.setup_python(context)
    10. self.setup_scripts(context)
    11. self.post_setup(context)

    每個方法 ensure_directories(), create_configuration(), setup_python(), setup_scripts() 和 post_setup() 都可以被重寫。

  • ensure_directories(env_dir)

    Creates the environment directory and all necessary subdirectories that don’t already exist, and returns a context object. This context object is just a holder for attributes (such as paths) for use by the other methods. If the EnvBuilder is created with the arg clear=True, contents of the environment directory will be cleared and then all necessary subdirectories will be recreated.

    The returned context object is a types.SimpleNamespace with the following attributes:

    • env_dir - The location of the virtual environment. Used for __VENV_DIR__ in activation scripts (see install_scripts()).

    • env_name - The name of the virtual environment. Used for __VENV_NAME__ in activation scripts (see install_scripts()).

    • prompt - The prompt to be used by the activation scripts. Used for __VENV_PROMPT__ in activation scripts (see install_scripts()).

    • executable - The underlying Python executable used by the virtual environment. This takes into account the case where a virtual environment is created from another virtual environment.

    • inc_path - The include path for the virtual environment.

    • lib_path - The purelib path for the virtual environment.

    • bin_path - The script path for the virtual environment.

    • bin_name - The name of the script path relative to the virtual environment location. Used for __VENV_BIN_NAME__ in activation scripts (see install_scripts()).

    • env_exe - The name of the Python interpreter in the virtual environment. Used for __VENV_PYTHON__ in activation scripts (see install_scripts()).

    • env_exec_cmd - The name of the Python interpreter, taking into account filesystem redirections. This can be used to run Python in the virtual environment.

    在 3.12 版更改: The attribute lib_path was added to the context, and the context object was documented.

    在 3.11 版更改: The venv sysconfig installation scheme is used to construct the paths of the created directories.

  • create_configuration(context)

    在環(huán)境中創(chuàng)建 pyvenv.cfg 配置文件。

  • setup_python(context)

    在環(huán)境中創(chuàng)建 Python 可執(zhí)行文件的拷貝或符號鏈接。在 POSIX 系統(tǒng)上,如果給定了可執(zhí)行文件 python3.x,將創(chuàng)建指向該可執(zhí)行文件的 pythonpython3 符號鏈接,除非相同名稱的文件已經(jīng)存在。

  • setup_scripts(context)

    將適用于平臺的激活腳本安裝到虛擬環(huán)境中。

  • upgrade_dependencies(context)

    升級環(huán)境中 venv 依賴的核心軟件包(當(dāng)前為 pipsetuptools)。通過在環(huán)境中使用 pip 可執(zhí)行文件來完成。

    3.9 新版功能.

  • post_setup(context)

    占位方法,可以在第三方實(shí)現(xiàn)中重寫,用于在虛擬環(huán)境中預(yù)安裝軟件包,或是其他創(chuàng)建后要執(zhí)行的步驟。

在 3.7.2 版更改: Windows 現(xiàn)在為 python[w].exe 使用重定向腳本,而不是復(fù)制實(shí)際的二進(jìn)制文件。僅在 3.7.2 中,除非運(yùn)行的是源碼樹中的構(gòu)建,否則 setup_python() 不會執(zhí)行任何操作。

在 3.7.3 版更改: Windows 將重定向腳本復(fù)制為 setup_python() 的一部分而非 setup_scripts()。在 3.7.2 中不是這種情況。使用符號鏈接時,將鏈接至原始可執(zhí)行文件。

此外,EnvBuilder 提供了如下實(shí)用方法,可以從子類的 setup_scripts() 或 post_setup() 調(diào)用,用來將自定義腳本安裝到虛擬環(huán)境中。

  • install_scripts(context, path)

    path 是一個目錄的路徑,該目錄應(yīng)包含子目錄 “common”, “posix”, “nt”,每個子目錄存有發(fā)往對應(yīng)環(huán)境中 bin 目錄的腳本。在下列占位符替換完畢后,將復(fù)制 “common” 的內(nèi)容和與 os.name 對應(yīng)的子目錄:

    • __VENV_DIR__ 會被替換為環(huán)境目錄的絕對路徑。

    • __VENV_NAME__ 會被替換為環(huán)境名稱(環(huán)境目錄的最后一個字段)。

    • __VENV_PROMPT__ 會被替換為提示符(用括號括起來的環(huán)境名稱緊跟著一個空格)。

    • __VENV_BIN_NAME__ 會被替換為 bin 目錄的名稱( binScripts )。

    • __VENV_PYTHON__ 會被替換為環(huán)境可執(zhí)行文件的絕對路徑。

    允許目錄已存在(用于升級現(xiàn)有環(huán)境時)。

有一個方便實(shí)用的模塊級別的函數(shù):

venv.create(env_dir, system_site_packages=False, clear=False, symlinks=False, with_pip=False, prompt=None, upgrade_deps=False)

通過關(guān)鍵詞參數(shù)來創(chuàng)建一個 EnvBuilder,并且使用 env_dir 參數(shù)來調(diào)用它的 create() 方法。

3.3 新版功能.

在 3.4 版更改: 添加 with_pip 參數(shù)

在 3.6 版更改: 添加 prompt 參數(shù)

在 3.9 版更改: 添加 upgrade_deps 參數(shù)

一個擴(kuò)展 EnvBuilder 的例子

下面的腳本展示了如何通過實(shí)現(xiàn)一個子類來擴(kuò)展 EnvBuilder。這個子類會安裝 setuptools 和 pip 到被創(chuàng)建的虛擬環(huán)境中。

 
 
 
 
  1. import os
  2. import os.path
  3. from subprocess import Popen, PIPE
  4. import sys
  5. from threading import Thread
  6. from urllib.parse import urlparse
  7. from urllib.request import urlretrieve
  8. import venv
  9. class ExtendedEnvBuilder(venv.EnvBuilder):
  10. """
  11. This builder installs setuptools and pip so that you can pip or
  12. easy_install other packages into the created virtual environment.
  13. :param nodist: If true, setuptools and pip are not installed into the
  14. created virtual environment.
  15. :param nopip: If true, pip is not installed into the created
  16. virtual environment.
  17. :param progress: If setuptools or pip are installed, the progress of the
  18. installation can be monitored by passing a progress
  19. callable. If specified, it is called with two
  20. arguments: a string indicating some progress, and a
  21. context indicating where the string is coming from.
  22. The context argument can have one of three values:
  23. 'main', indicating that it is called from virtualize()
  24. itself, and 'stdout' and 'stderr', which are obtained
  25. by reading lines from the output streams of a subprocess
  26. which is used to install the app.
  27. If a callable is not specified, default progress
  28. information is output to sys.stderr.
  29. """
  30. def __init__(self, *args, **kwargs):
  31. self.nodist = kwargs.pop('nodist', False)
  32. self.nopip = kwargs.pop('nopip', False)
  33. self.progress = kwargs.pop('progress', None)
  34. self.verbose = kwargs.pop('verbose', False)
  35. super().__init__(*args, **kwargs)
  36. def post_setup(self, context):
  37. """
  38. Set up any packages which need to be pre-installed into the
  39. virtual environment being created.
  40. :param context: The information for the virtual environment
  41. creation request being processed.
  42. """
  43. os.environ['VIRTUAL_ENV'] = context.env_dir
  44. if not self.nodist:
  45. self.install_setuptools(context)
  46. # Can't install pip without setuptools
  47. if not self.nopip and not self.nodist:
  48. self.install_pip(context)
  49. def reader(self, stream, context):
  50. """
  51. Read lines from a subprocess' output stream and either pass to a progress
  52. callable (if specified) or write progress information to sys.stderr.
  53. """
  54. progress = self.progress
  55. while True:
  56. s = stream.readline()
  57. if not s:
  58. break
  59. if progress is not None:
  60. progress(s, context)
  61. else:
  62. if not self.verbose:
  63. sys.stderr.write('.')
  64. else:
  65. sys.stderr.write(s.decode('utf-8'))
  66. sys.stderr.flush()
  67. stream.close()
  68. def install_script(self, context, name, url):
  69. _, _, path, _, _, _ = urlparse(url)
  70. fn = os.path.split(path)[-1]
  71. binpath = context.bin_path
  72. distpath = os.path.join(binpath, fn)
  73. # Download script into the virtual environment's binaries folder
  74. urlretrieve(url, distpath)
  75. progress = self.progress
  76. if self.verbose:
  77. term = '\n'
  78. else:
  79. term = ''
  80. if progress is not None:
  81. progress('Installing %s ...%s' % (name, term), 'main')
  82. else:
  83. sys.stderr.write('Installing %s ...%s' % (name, term))
  84. sys.stderr.flush()
  85. # Install in the virtual environment
  86. args = [context.env_exe, fn]
  87. p = Popen(args, stdout=PIPE, stderr=PIPE, cwd=binpath)
  88. t1 = Thread(target=self.reader, args=(p.stdout, 'stdout'))
  89. t1.start()
  90. t2 = Thread(target=self.reader, args=(p.stderr, 'stderr'))
  91. t2.start()
  92. p.wait()
  93. t1.join()
  94. t2.join()
  95. if progress is not None:
  96. progress('done.', 'main')
  97. else:
  98. sys.stderr.write('done.\n')
  99. # Clean up - no longer needed
  100. os.unlink(distpath)
  101. def install_setuptools(self, context):
  102. """
  103. Install setuptools in the virtual environment.
  104. :param context: The information for the virtual environment
  105. creation request being processed.
  106. """
  107. url = 'https://bitbucket.org/pypa/setuptools/downloads/ez_setup.py'
  108. self.install_script(context, 'setuptools', url)
  109. # clear up the setuptools archive which gets downloaded
  110. pred = lambda o: o.startswith('setuptools-') and o.endswith('.tar.gz')
  111. files = filter(pred, os.listdir(context.bin_path))
  112. for f in files:
  113. f = os.path.join(context.bin_path, f)
  114. os.unlink(f)
  115. def install_pip(self, context):
  116. """
  117. Install pip in the virtual environment.
  118. :param context: The information for the virtual environment
  119. creation request being processed.
  120. """
  121. url = 'https://bootstrap.pypa.io/get-pip.py'
  122. self.install_script(context, 'pip', url)
  123. def main(args=None):
  124. compatible = True
  125. if sys.version_info < (3, 3):
  126. compatible = False
  127. elif not hasattr(sys, 'base_prefix'):
  128. compatible = False
  129. if not compatible:
  130. raise ValueError('This script is only for use with '
  131. 'Python 3.3 or later')
  132. else:
  133. import argparse
  134. parser = argparse.ArgumentParser(prog=__name__,
  135. description='Creates virtual Python '
  136. 'environments in one or '
  137. 'more target '
  138. 'directories.')
  139. parser.add_argument('dirs', metavar='ENV_DIR', nargs='+',
  140. help='A directory in which to create the '
  141. 'virtual environment.')
  142. parser.add_argument('--no-setuptools', default=False,
  143. action='store_true', dest='nodist',
  144. help="Don't install setuptools or pip in the "
  145. "virtual environment.")
  146. parser.add_argument('--no-pip', default=False,
  147. action='store_true', dest='nopip',
  148. help="Don't install pip in the virtual "
  149. "environment.")
  150. parser.add_argument('--system-site-packages', default=False,
  151. action='store_true', dest='system_site',
  152. help='Give the virtual environment access to the '
  153. 'system site-packages dir.')
  154. if os.name == 'nt':
  155. use_symlinks = False
  156. else:
  157. use_symlinks = True
  158. parser.add_argument('--symlinks', default=use_symlinks,
  159. action='store_true', dest='symlinks',
  160. help='Try to use symlinks rather than copies, '
  161. 'when symlinks are not the default for '
  162. 'the platform.')
  163. parser.add_argument('--clear', default=False, action='store_true',
  164. dest='clear', help='Delete the contents of the '
  165. 'virtual environment '
  166. 'directory if it already '
  167. 'exists, before virtual '
  168. 'environment creation.')
  169. parser.add_argument('--upgrade', default=False, action='store_true',
  170. dest='upgrade', help='Upgrade the virtual '
  171. 'environment directory to '
  172. 'use this version of '
  173. 'Python, assuming Python '
  174. 'has been upgraded '
  175. 'in-place.')
  176. parser.add_argument('--verbose', default=False, action='store_true',
  177. dest='verbose', help='Display the output '
  178. 'from the scripts which '
  179. 'install setuptools and pip.')
  180. options = parser.parse_args(args)
  181. if options.upgrade and options.clear:
  182. raise ValueError('you cannot supply --upgrade and --clear together.')
  183. builder = ExtendedEnvBuilder(system_site_packages=options.system_site,
  184. clear=options.clear,
  185. symlinks=options.symlinks,
  186. upgrade=options.upgrade,
  187. nodist=options.nodist,
  188. nopip=options.nopip,
  189. verbose=options.verbose)
  190. for d in options.dirs:
  191. builder.create(d)
  192. if __name__ == '__main__':
  193. rc = 1
  194. try:
  195. main()
  196. rc = 0
  197. except Exception as e:
  198. print('Error: %s' % e, file=sys.stderr)
  199. sys.exit(rc)

這個腳本同樣可以 在線下載。


網(wǎng)站名稱:創(chuàng)新互聯(lián)Python教程:venv—-創(chuàng)建虛擬環(huán)境
網(wǎng)站鏈接:http://www.dlmjj.cn/article/dpdhggh.html