https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_b964594d3d957944241961017b9eb19bf02834de44cce93d8e67dd306852dbe346167181e455e33d5268ea01d973d77bb056848546f31794f31a4c31a9da5aa3.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_23f1ae74c634d7e5e0a067c22b7a8c2d79c3ffd9a3b9395fc82c1b3b99635552b994f1f72f532f28ceaff1ea054ea026cd488cd62fa03a4ad91d212b5f3c5a72.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_451c3884f51125f7687e5bb07cfab033c04cb7174c33f93213b2af4bad2af13cf48b92a7fa95fc86d7d436f355938a3ac50aa119cdb7c9b6d5a52815c3e6033e.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_bfff9e63e857e9ee612e292d4a6edf3ced64d6a756925c953a9d8f77845ff601eca64d73dfa48756b1a9f4a4d6de6127a273bcde16ddeb71a22383460f4e94b0.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_f4dd7e1d73ae5eda35ed5ad6aa965b612dbf483ece3ca50c1e8e30ad8dff1c66a160ed75e958e2db399661d229874783e0834ad813a479437035666b8e9e3386.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_4fce0769137d4cd096989b0349bc3c2bbfca79ac311fdf714c41ab24d87551c7b49b756c8a8de090b0714a0ad0560e49fa532ba5a88875ea4afd78efac464df6.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_85cec8b07d60426b11040e471babca0d2f9c8dc87a9b56e06cad39828f7f67179e29609100f282a574872c9a93fb635b25416300eb4c97bc5a653d00cf6f8dbf.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_6768e5a27d4d357347338621c0d20bd269b126d30eec796193390f2f530fbaea60af84130c46f9786114be65149e661e87d55c339219c90aa76396d7e5b734ef.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_2acd6bdff3b680341e8c727da5169a647123eb8fd0a90253161b4c3af272c15d293bf9bb217008bb13f84d1910b0e166798001f8603b6c026d5c20a76c41d47c.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_cd26968e74878e26fa919a980e692cb151f383a2190fce5ebda2e6186b4f0dca989fd9410386e77ab544118b9bf15ae96e6bd62137e25e48ea6a0b10d15d3745.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_268c9bba6ba649318f0da28c37b09a9bbfa371210f9b6b52faa7fd8ae94abf6b3c3bfeb5df5705c93495ce1152ca58aeabc435d6c6c1bd959025165c3f50e086.js
  • Skip to main content
  • Skip to primary sidebar
  • Skip to footer
  • Home
  • Featured
    • Advanced Python Topics
    • AWS Learning Roadmap
    • JWT Complete Guide
    • Git CheatSheet
  • Explore
    • Programming
    • Development
      • microservices
      • Front End
    • Database
    • DevOps
    • Productivity
    • Tutorial Series
      • C# LinQ Tutorials
      • PHP Tutorials
  • Dev Tools
    • JSON Formatter
    • Diff Checker
    • JWT Decoder
    • JWT Generator
    • Base64 Converter
    • Data Format Converter
    • QR Code Generator
    • Javascript Minifier
    • CSS Minifier
    • Text Analyzer
  • About
  • Contact
CodeSamplez.com

CodeSamplez.com

Programming And Development Resources

You are here: Home / Development / Python Virtual Environment: A Beginner’s Step By Step Guide

Python Virtual Environment: A Beginner’s Step By Step Guide

Updated July 17, 2025 by Rana Ahsan Leave a Comment ⏰ 7 minutes

Beginner's Guide To Python Virtual Environment

Python virtual environments are a lifesaver for any developer juggling multiple projects. They let you isolate each project’s libraries to avoid version conflicts and messy global installs. In this beginner’s guide, we’ll explain what virtual environments are, why they matter, and how to set one up step by step to keep your Python projects clean and conflict-free.

🐍 What Is A Python Virtual Environment?

A Python virtual environment is an isolated workspace that contains its own Python interpreter and package installations, separate from your system’s global Python setup.

Simple illustration of how python's virtual environment isolates dependencies for projects

🤔 Why Use Virtual Environments In Python?

Different projects often require different versions of packages or even different Python versions. Without virtual environments, installing packages globally can create conflicts – for example, Project A might need Django 3.2 while Project B requires Django 4.0.

Virtual environments solve this beautifully, by giving each project its own isolated space. They let you:

  1. Isolation is Key: Keep dependencies tidy and project-specific.
  2. Clear of Conflict: Avoid version conflicts with other global packages (no more shouting matches between numpy versions).
  3. Reproducibility: Easily share your exact project dependencies with teammates.

And bonus: Nothing says “I’ve got this” like a well-organized workspace.

🔧 Setting Up Your First Python Virtual Environment (Step-by-Step)

Let’s roll up our sleeves and set up a virtual environment. I promise—it’s easier than assembling an IKEA furniture.

Step 1: Check Your Python Version

First, make sure Python is installed (duh). Open your terminal and type:

python --version
Bash

Or, depending on your setup:

python3 --version
Bash

Got Python 3.6+? You’re good to go. If not, head over to python.org and grab the latest version.

Step 2: Create a Python Virtual Environment

Navigate to your project folder in the terminal. For example:

cd ~/my-project
Bash

Now, create a virtual environment:

python3 -m venv venv
Bash

Let’s unpack that:

  • python3: Calls Python 3 (you can also use python it if that’s your default).
  • -m venv: Activates the built-in virtual environment module.
  • venv: The name of your virtual environment folder (feel free to name it something else, like magic-kitchen).

After running this, you’ll see a new folder (venv) in your project directory. That’s your shiny new virtual environment! 🎉

Step 3: Activate the Virtual Environment

Here’s where the magic happens. To activate your virtual environment:

  • On macOS/Linux:
source venv/bin/activate
Bash

On Windows:

.\venv\Scripts\activate
Bash

When activated, your terminal prompt will change to something like this:

(venv) $
Bash

This little (venv) prefix is like a neon sign reminding you that you’re inside the virtual environment.

Step 4: Install Packages Without Fear

Now you’re in your private kitchen. Go ahead and install whatever libraries you need in python your virtual environment. For example:

pip install requests
Bash

To double-check what’s installed:

pip list
Bash

Feel the serenity. Notice how none of this messes with your system Python. It’s a beautiful thing.

Step 5: Creating a Requirements File

Now, let’s say you want to share your project with a friend (or your future self). You can create a requirements.txt file that lists all your project’s dependencies:

pip freeze > requirements.txt
Bash

Step 6: Deactivate When You’re Done

When you’re finished cooking, deactivate the virtual environment:

deactivate
Bash

Poof! You’re back to your system Python version. No harm, no foul.

💬 Use Different Python Versions for each Virtual Environment

Need to use a different Python version for each/some of the different virtual environments you just created? Okie dokie. I already covered it in a separate post of Python version management to help you achieve exactly that. Go ahead and read more on that!

🚨 Pro Tips for Virtual Environment Ninjas

  • Use .gitignore: If you’re working on a project with version control, don’t commit the venv folder. Add it to your .gitignore file.
  • Name Your Environments Wisely: If you’ve got multiple projects, give your virtual environments meaningful names like env-django or env-flask.
  • Automate Activation: Consider using tools  direnv to automatically activate your virtual environment when you enter your project directory. It’s like having a personal assistant for your development workflow.

🛠 Common Mistakes

  • Forgetting to Activate: If you see the ModuleNotFoundError while trying to run your Python project, you might have forgotten to activate the virtual environment.
  • Cluttering Your Global Python: Don’t fall back into the old habit of installing globally. That’s how the chaos starts.

💡Tools of the Trade: Beyond venv

While venv is great, these alternatives also worth considering:

  • Conda: Awesome for data science projects
  • Poetry: Dependency management on steroids
  • Pipenv: Combines pip and virtualenv

💬 Wrapping Up

Python virtual environments are like the secret sauce to hassle-free development. They keep your projects clean, your dependencies organized, and your sanity intact. Once you get the hang of it, you’ll wonder how you survived without them. There’s nothing more satisfying than setting up your project without dealing with dependency conflict.

So go ahead, create that virtual environment, and start building your next masterpiece—whether it’s a chatbot, a game, or, who knows, the next Netflix for dogs. Just don’t forget to deactivate when you’re done. 😉

Do you have any virtual environment horror stories or victories? Share them in the comments—I’d love to hear! I hope this tutorial has helped get you started with Python Virtual Environment. Happy coding! 🐍

Quick Workflow Cheat Sheet

# Create
python -m venv myenv

# Activate
source myenv/bin/activate  # Unix
myenv\Scripts\activate     # Windows

# Install packages
pip install package_name

# Save dependencies
pip freeze > requirements.txt

# Deactivate
deactivate
Bash

Python Virtual Environment FAQs

Is venv the same as virtualenv?

Not exactly. venv is Python’s built-in module (since 3.5+) for creating virtual environments, whereas virtualenv is an older third-party tool that served a similar purpose. In modern Python versions, venv is the recommended approach.

How do I activate or deactivate a virtual environment?

To activate, run env\Scripts\activate on Windows, or source env/bin/activate on macOS/Linux. Your prompt will change to show the env name. When done, type deactivate to exit the environment and return to the system Python.

Should I use a virtual environment for every project?

Yes. It’s best to create a new virtual environment for each Python project. This keeps that project’s dependencies isolated, preventing version conflicts between projects and keeping your global Python installation clean.

Can I have multiple Python versions using virtual environments?

Yes. You can specify a Python version when creating the venv (e.g. run python3.10 -m venv myenv to use Python 3.10). Each virtual environment is tied to the interpreter it was created with, so you can maintain separate envs for different Python versions.

What’s the difference between venv and Conda environments?

venv is a built-in tool that isolates Python packages for a project. Conda is an external package and environment manager that can handle both Python packages and other dependencies (like C libraries). Conda allows switching Python versions and is popular in data science, but it requires installing Anaconda/Miniconda.

Share if liked!

  • Click to share on Facebook (Opens in new window) Facebook
  • Click to share on X (Opens in new window) X
  • Click to share on LinkedIn (Opens in new window) LinkedIn
  • Click to share on Pinterest (Opens in new window) Pinterest
  • Click to share on Reddit (Opens in new window) Reddit
  • Click to share on Tumblr (Opens in new window) Tumblr
  • Click to share on Pocket (Opens in new window) Pocket

You may also like


Discover more from CodeSamplez.com

Subscribe to get the latest posts sent to your email.

First Published On: December 12, 2024 Filed Under: Development Tagged With: python

About Rana Ahsan

Rana Ahsan is a seasoned software engineer and technology leader specialized in distributed systems and software architecture. With a Master’s in Software Engineering from Concordia University, his experience spans leading scalable architecture at Coursera and TopHat, contributing to open-source projects. This blog, CodeSamplez.com, showcases his passion for sharing practical insights on programming and distributed systems concepts and help educate others.
Github | X | LinkedIn

Reader Interactions

Leave a ReplyCancel reply

Primary Sidebar

  • Facebook
  • X
  • Pinterest
  • Tumblr

Subscribe via Email

Top Picks

python local environment setup

Python Local Development Environment: Complete Setup Guide

In-Depth JWT Tutorial Guide For Beginners

JSON Web Tokens (JWT): A Complete In-Depth Beginners Tutorial

The Ultimate Git Commands CheatSheet

Git Commands Cheatsheet: The Ultimate Git Reference

web development architecture case studies

Web Development Architecture Case Studies: Lessons From Titans

static website deployment s3 cloudfront

Host Static Website With AWS S3 And CloudFront – Step By Step

Featured Dev Tools

  • JSON Formatter
  • JWT Decoder

Recently Published

service worker framework integration

Service Workers in React: Framework Integration Guide

service worker caching strategies

Service Worker Caching Strategies: Performance & Offline Apps

service worker lifecycle

Service Worker Lifecycle: Complete Guide for FE Developers

what is service worker

What Is a Service Worker? A Beginner’s Guide

Dynamic Typing In Python

Dynamic Typing in Python: A Comprehensive Guide For Beginners

Footer

Subscribe via Email

Follow Us

  • Facebook
  • X
  • Pinterest
  • Tumblr

Explore By Topics

Python | AWS | PHP | C# | Javascript

Copyright © 2025

https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_59cba7607144bdd373e4aa6011e133fc8a5045f1c7503115b3e680324ce757657961b4d55c4016493ffd5ad0c6981e1a00cef906d94e197ab59be1a2c8359395.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_c402e38f1879c18090377fb6b73b15ac158be453ecda3a54456494fe8aba42b990c293bae5424e5643d52515ffc2067e0819995be8d07d5bba9107a96780775c.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_ffc3511227531cc335353c54c3cbbaa11d0b80e5cb117478e144436c13cd05495b67af2e8950480ed54dbdabcdcef497c90fdb9814e88fe5978e1d56ce09f2cf.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_d57da9abfef16337e5bc44c4fc6488de258896ce8a4d42e1b53467f701a60ad499eb48d8ae790779e6b4b29bd016713138cd7ba352bce5724e2d3fe05d638b27.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_edc0e9ef106cc9ef7edd8033c5c6fcff6dc09ee901fd07f4b90a16d9345b35a06534f639e018a64baaf9384eee1df305570c1ecad747f41b787b89f53839962b.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_bc2182bb3de51847c8685df18692deda654dbf90fb01b503eb1bb0b68b879a051b91f30a9210ed0b2ba47c730db14b159cd9391ffdcd7117de397edd18366360.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_dccc492dbbfdac33d1411f9df909e849c7268fcf99b43007f278cde3a0adc0ae00e8cae5ec81cf255b9a6eae74e239ba1fa935572af77173219cb081f7d2327d.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_00bacf9e36181aac2b666d110cd9d82257f846766e7041b2d7b3c909b458982931ccc9b203e37098fbdfcf43ca359cf04e3824a724a6789fc204196d3a72ad29.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_55bf3a9e3a811e7da324e259853b19b3fd502a544149b47779911b6759f5573213d9f6c35ae9e76137f006ee03242384d44ae32bb6792415b7ceda4215b1afb6.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_aa5a5d229b421633f4247380e1e8c0a4854f82efb35d13a5b07b7b8fbe22e98842a580f063e5965345a51c477a7f5c2585edf8dd7d896b2438dc61f91d8d970c.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_bb8058a9e234a7ffaa98891b1df7f6b8e67410e6984568b151daa05113b8c7f89d7b5918ae73f020998a16f7f5a087a13d6a9a5e5d7c301e2ca12fd9d1f8d177.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_647fb67570c6108fb10ae6785a1abdbecac99ffcf80351d0bef17c3cf783dce497b1895fcdaae997dacc72c359fbfb128cc1540dd7df56deb4961e1cd4b22636.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_f7a298a0f1f754623fe3b30f6910ce2c1373f715450750bd7a391571812b00df1917e2be90df6c4efc54dbdfda8616278a574dea02ba2c7a31992768df8db334.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_df30604d5842ef29888c3c1881220dc6d3f8854666d94f0680c5f38aa643c5fb79b10eb9f10998d8856eb24ca265783195937434fd6c2bb8e4846df0277a7fb7.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_f17fe6fb0993f1703181d7ae9e9ea570f3d33a43afd6f2a4567daa1a6745698c7b8193dc72d50991d2dd87cd3dcf663959206607d193a9b57926d061a1f50aef.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_945dcbab2c2a131f3c90f4fb91776b76066d589f84fb55bff25cd5d79a56218000616bfca1f0af9a74f32348693707af49e8fe624de8aa34f1e1c5b6a25709cf.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_65820d252e1b93596de6697fd5f02483f3e2524a0696c7d698b64745edb32bf5831a90e556842f5f88c8209766cc78ca3a41cf783d20236a9f90d4a7ea7b3e72.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_7286884797a1210857e2a36f8ab46604b0034b6abf512380447a5763c873db6a72b8547f660053de0ea69faef1eb64878f39ff4b0ea86c963efab95764a3bf5b.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_cbcf6c279ac6c6a25ae138bf964e64a5fd90d22dcdf8a53b6fe7b72cefa51063bfb0181a6e50dd2acdcae2795619887d1d83b10461e44e5103be756f2588d837.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_47965bc586b95810c925b9df3314e0c9a5cd121e70ca0831f87df0bc034695de4f83ecf2def86f737e14614ee138794473cf32cd3082a5d38db9dec0c1f266fa.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_12aa201cea075846d266536aa222d64d4088b851d87f55dac5e611b77add6826c8ebc6e82650fcd1a9e88a05a0072dedd195719c5f64cd4580a0acd8aee05d92.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_eaa93529c38925eb07368c361382956fbd910b5106b8589fa7e2e15a59c46437de3698d50ec4754bc45e6dfac47b3f41cc4c6112d7ede071ca8950385d4987dc.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_9f1cb510da47e323857ccc56e98ccfb8951c61cde6b60dfe2766db6896d201ba501855ba940fdf37ba47df2a5f3d4117a398b6262ce467d89eacac04034ea356.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_d87ea86dd0e7ecdd5fe7a5bb67becf943e57c3add866b456034d51663d099031bd563e12f61fdccc044969adf938a8584ed22ccd401ab8b669e20e4f92fb54e8.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_35311c3d71a3605fad4e1d6b50f3911311cdcc46418bdf56d6d0308a75a69585269ee7582a335e29989adf308fa1a81a10a2c2d4e257e9d680447a4996f6269e.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_ed203ae78cbd5d0d7f0de78c3fc2160c89a1f23ae60fe4dedd0f2422beb9b63f801d45786553e4ed4913fc57caaf8cad3112579c33c8914e339634f35e3cc4e8.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_4d1fae16f3501b97ac1dbc8ca35997b3d3899c98dd478a204920e92de4a093d0c2e9ab1ccbc16b0c3423c0be3ef59d7aaefc6edd559961e5169236aa4c73c7f7.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_f4fc182ef03c12e9dcadd6febc3dbaa4a29134469057ca9e8ec0be2f2de29a494514ff4b59798e74debf26f78b2df2b3e2665c69b77035761fb463b783202915.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_85c0f2769456e60153b0fd8364b82a035da53384f62de342d9bdca806f3f1ea56486919a00497a18d457949c82bf8bfacc4423fc332074ddf71a49a8fe628fff.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_67f99bef3678c549a14b5f2ff790cce6aba338dca29020755444231b45fa0f980f795e3658496ba70739a099b47b22bc2eab564343ac6132309de3adbbae3455.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_09eecfdd96206ed13830b4b93cfb2cc75cd38083671a34194437b5734b5bb38712209dc335b07e3266ceb3c3a44a155b9bbe5f3e0e1105b19dd45d3def76f020.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_4c089fbdb88e3b624a6f884d3ba1bf606f003bfcd3742376d0d353cd62181dc663aa3811a56361c3100de488fc4d6595a50de2b26f058921ba74f5f2c1b5be00.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_897ff6ac314c5f5e0f496c6af624bd9abf296a02cb5aeb850b9220b6dc3ce2fc4004cb02ed8b59d59d4b9c9d90f050d6eebc1d08ecaebab2f671f7d9367e6410.js
https://codesamplez.com/wp-content/cache/breeze-minification/js/breeze_67d1e619e71d36ae00ddcf85ee18628bb4eb64fcb3d6119b463e75cb987013420a21136d19cd03e6634ccc01cfa9af4a357930e4cf6900953b7812efb4f249fb.js