78 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: Installing and Using Python 3
 | |
| ---
 | |
| 
 | |
| ## Installing Python 3
 | |
| You can download Python from this official <a href='https://www.python.org/downloads/' target='_blank' rel='nofollow'>link</a>. Based on your OS (Windows or Linux or OSX), you might want to install Python 3 following <a href='http://docs.python-guide.org/en/latest/starting/installation/' target='_blank' rel='nofollow'>these instructions</a>.
 | |
| 
 | |
| ## Using Virtual Environments
 | |
| It is always a great idea to <a href='https://en.wikipedia.org/wiki/Sandbox_(computer_security)' target='_blank' rel='nofollow'>sandbox</a> your Python installation; and keeping it separate from your _System Python_. The _System Python_ is the path to Python interpreter, which is used by other modules installed along with your OS.
 | |
| 
 | |
| It's **not safe** to install Python Web-frameworks or libraries directly using _System Python_. Instead, you can use <a href='https://virtualenv.readthedocs.org/en/latest/' target='_blank' rel='nofollow'>Virtualenv</a> to create and spawn a separate Python process when you are developing Python applications.
 | |
| 
 | |
| ### Virtualenvwrapper
 | |
| The <a href='https://virtualenvwrapper.readthedocs.org/en/latest/' target='_blank' rel='nofollow'>Virtualenvwrapper module</a> makes it easy for you to manage and sandbox multiple Python sandboxed environments in one machine; without corrupting any modules or services written in Python and used by your machine.
 | |
| 
 | |
| Of course, most cloud hosted development environment such as <a href='https://www.nitrous.io/' target='_blank' rel='nofollow'>Nitrous</a> or <a href='https://c9.io/' target='_blank' rel='nofollow'>Cloud9</a> also comes with these pre-installed and ready for you to get coding! You can quickly pick a box from your dashboard, and start coding after activating a Python 3 environment.
 | |
| 
 | |
| In <a href='https://c9.io/' target='_blank' rel='nofollow'>Cloud9</a>, you need to select the Django box while creating a new development environment.
 | |
| 
 | |
| A few shell command examples would follow. If you wish to copy-paste, do note that the `$` sign is a shorthand for the terminal prompt, it's not part of the command. My terminal prompt looks something like this:
 | |
| 
 | |
|     alayek:~/workspace (master) $
 | |
| 
 | |
| And, an `ls` would look like
 | |
| 
 | |
|     alayek:~/workspace (master) $ ls
 | |
| 
 | |
| But, while writing the same in this documentation, I would be writing it as
 | |
| 
 | |
|     $ ls
 | |
| 
 | |
| Getting back to our discussion, you can create a Python 3 interpreter-included sandbox on Cloud9 by running on your cloud terminal:
 | |
| 
 | |
|     $ mkvirtualenv py3 --python=/usr/bin/python3
 | |
| 
 | |
| You have to run it only once after creating a new box for your project. Once executed, this command would create a new sandboxed virtualenv ready for you to use, named `py3`.
 | |
| 
 | |
| To view available virtual environments, you can use
 | |
| 
 | |
|     $ workon
 | |
| 
 | |
| To activate `py3`, you can use the `workon` command with the name of the environment:
 | |
| 
 | |
|     $ workon py3
 | |
| 
 | |
| All three terminal commands above would also work on local Linux machines or OSX machines. These are <a href='https://virtualenvwrapper.readthedocs.org/en/latest/#introduction' target='_blank' rel='nofollow'>virtualenvwrapper</a> commands; so if you are planning on using them, make sure you have this module installed and added to `PATH` variable.
 | |
| 
 | |
| If you are inside a virtual environment; you can easily find that out by checking your terminal prompt. The environment name would be clearly shown in your terminal prompt.
 | |
| 
 | |
| For instance, when I am inside the `py3` environment; I would be seeing this as my terminal prompt:
 | |
| 
 | |
|     (py3)alayek:~/workspace (master) $
 | |
| 
 | |
| Notice the `(py3)` in braces! If for some reason, you are not seeing this, even if you are inside a virtual env; you can try doing one of the things <a href='http://stackoverflow.com/questions/1871549/python-determine-if-running-inside-virtualenv' target='_blank' rel='nofollow'>mentioned here</a>.
 | |
| 
 | |
| To get out of a virtual environment; or to deactivate one - use the command
 | |
| 
 | |
|     $ deactivate
 | |
| 
 | |
| Again, this works only with virtualenvwrapper module.
 | |
| 
 | |
| ### Pipenv
 | |
| 
 | |
| An alternative to using virtualenvwrapper is [Pipenv](https://docs.pipenv.org/). It automatically creates virtual environments for your projects, and maintains a `Pipfile` which contains the dependencies. Using Pipenv means you no longer need to use pip and virtualenv separately, or manage your own `requirements.txt` file. For those familiar with JavaScript, Pipenv is similar to using a packaging tool like `npm`.
 | |
| 
 | |
| To get started with Pipenv, you can follow this very detailed [guide](https://docs.pipenv.org/install.html#installing-pipenv). Pipenv makes it easy to [specify which version of Python](https://docs.pipenv.org/basics.html#specifying-versions-of-python) you wish to use for each project, [import](https://docs.pipenv.org/basics.html#importing-from-requirements-txt) from an existing `requirements.txt` file and [graph](https://docs.pipenv.org/#pipenv-graph) your dependencies.
 | |
| 
 | |
| ## Installing packages using pip(Python Installer Package):
 | |
| ```
 | |
| pip3 install <package-name>
 | |
| ```
 | |
| ```
 | |
| pip3 install numpy #example
 | |
| ```
 | |
| 
 | |
| 
 | |
| 
 |