Difference between revisions of "OPS435 Python Lab 1"

From CDOT Wiki
Jump to: navigation, search
(PART 1 - Installing Your Linux Distribution)
 
(205 intermediate revisions by 5 users not shown)
Line 1: Line 1:
 +
<font color='red'>
 +
'''** DO NOT USE - TO BE UPDATED FOR CENTOS 8.0 **'''
 +
</font>
 
= LAB OBJECTIVES =
 
= LAB OBJECTIVES =
  
:In this lab, you will first select and install a current distribution of Linux to be used as a host machine. You will NOT be required to setup Virtual Machines for this lab (that will be covered in a future lab). You will then setup your Python scripting environment on your host machine. This environment setup the '''python''' libraries and will also include a user-friendly interactive Python environment called '''ipython'''. You will also install additional framework tools (such as '''git''', '''vim''', and '''tmux''') to be used in later labs.
+
:In this lab, you will install a current distribution of Linux in a Virtual Machine on your external SSD. You will do all of your future work within this VM (including quizzes!). You will then setup your Python scripting environment on your host machine, including the setup the of '''python''' libraries and also the setup of a user-friendly interactive Python environment called '''ipython'''. You will also install additional framework tools (such as '''git''', '''vim''', and '''tmux''') to be used in later labs.
  
:After selecting an appropriate text editor to use, then you will start to create '''Python''' scripts to learn basic operations such as: '''printing text''', '''using variables''', and performing '''math operations'''.
+
:After selecting an appropriate text editor to use, then you will start to create '''Python''' scripts to learn basic operations such as: '''printing text''', '''using objects''', and performing '''math operations'''.
 +
<br><br>
  
 
= INVESTIGATION 1: INSTALLING LINUX VM=
 
= INVESTIGATION 1: INSTALLING LINUX VM=
Line 10: Line 14:
  
 
<!-- Try to use tables and simplify the layers of WIKI to make top links less verbose to students -->
 
<!-- Try to use tables and simplify the layers of WIKI to make top links less verbose to students -->
 +
 +
:Centos 7 - release 1810 will be used for this course. The purpose for this is to allow you to use a consistent and stable '''RedHat''' based OS, and to lower the amount of new linux distros that you need to learn.
  
:Since Python runs <u>independently</u> regardless the of the Linux distribution, you have some flexibility of which Linux OS to use.  
+
: Most of you will likely use the school's Windows machines with the Vmware hypervisor. It is also possible to use your own computer, but check with your professor before you do that.
  
:The stable version of Centos 7 - release 1161 will be chosen(tested) to be supported for this course. This is to keep the ops stream on red hat based systems, lower the amount of new linux distros that need to be learned by students. This should be the default choice for this course, as it allows for the course to run longer before getting outdated with new software and updates.
+
:Centos 7 comes with python 2.7, for this course we will be primarily using Python3. However, not practicing python 2.7 would be a mistake, since so many programs and operating systems still depend on Python2. It is recommended that students note general improvements/differences in Python2 and Python3.
  
 
:Centos 7 comes with python 2.7, which means that it is not optimal out for the box for teaching this course. However not teaching python 2.7 would be a mistake since so many programs and operating systems still depend on python 2. It would be good to note some changes and encourage new work to be done in python3 while paying attention to specific projects that work only with python 2.
 
  
 
:'''<u>Centos 7 VM Details / Minimum Requirements:</u>'''
 
:'''<u>Centos 7 VM Details / Minimum Requirements:</u>'''
  
::*'''Name:''' c7host
+
::*'''Name:''' centos7
 
::*'''Boot media / Installation:''' CentOS7 Full Install DVD
 
::*'''Boot media / Installation:''' CentOS7 Full Install DVD
:::*Download at Seneca College: CentOS 7 Full Install DVD (image file): http://belmont.senecacollege.ca/pub/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1611.iso
+
:::*Download at Seneca College: CentOS 7 Full Install DVD (image file): http://belmont.senecacollege.ca/pub/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1810.iso
:::*Download outside Seneca College: http://mirror.csclub.uwaterloo.ca/centos/7/isos/x86_64/CentOS-7-x86_64-Everything-1611.iso
+
:::*Download outside Seneca College: http://mirror.csclub.uwaterloo.ca/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1810.iso
::*'''Disk space:''' XGB
+
::*'''Disk space:''' 50GB
::*'''CPUs:''' X
+
::*'''CPUs:''' 4 (Number of processors: 1, Number of cores per processor: 4)
::*'''Internal Memory:''' X
+
::*'''Internal Memory:''' 8GB
 +
::*'''Environment:''' GNOME Desktop
  
 
<!--==== Environment Setup ====
 
<!--==== Environment Setup ====
Line 45: Line 50:
  
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
 
 
:#Regardless of the Linux distribution you decide to use for this course, this lab will be using and referring to the current version of '''Centos7''', and install the Graphical Desktop for our host machine. When you have finished the installation of Centos7, you may move on to the next steps.
 
  
<blockquote style="margin-left:35px;">{{Admon/important|style="padding-left:25px"|Unit Evaluation Scripts|Each '''Part''' (within an 'Investigation) is referred to as a '''Unit'''. Each Unit will require that the student download and run a '''Unit Evaluation Script''', which can be used to look at a student's Python scripts that was created in order to provide "real-time feedback".<br>This feedback is not considered to be perfect or fool-proof; however, it may provide feedback (hints) in case a student gets stuck or experiences an error when running thier Python scripts. These unit evaluation scripts can also be used to confirm that the student's Python script is on the right track, and provide a consist record of their Python scripting progress throughout their labs.}}</blockquote>
+
:#Regardless of the Linux distribution that is used for this course, these lab will be using and referring to the current version of '''CentOS 7''' (Graphical Desktop) for our main Linux machine. When creating your VM, refer to the '''Details / Minimum Requirements''' section above for assistance.
 +
:#Install CentOS 7 VM selecting the default partitions. When you have finished the installation of CentOS 7, you may proceed to the next step.
 +
<blockquote style="margin-left:35px;">{{Admon/important|style="padding-left:25px"|Unit Feedback Scripts|Each '''Part''' (within an 'Investigation) is referred to as a '''Unit'''. Each Unit will require that the student download and run a '''Unit Feedback Script''', which provides the OPS435 student "real-time feedback" of their completed work.<br>This feedback is not considered to be perfect or fool-proof; however, it may provide feedback (hints) in case a student gets stuck or experiences an error when performing administration tasks or when creating their Python scripts. These unit feedback scripts can also be used to confirm that the student's Python script is on the right track, and provide a consistent record of their Python scripting progress throughout their labs.}}</blockquote>
  
<ol><li value="2" style="margin-left:25px;">Issue the following commands in order to setup, download and run the first unit evaluation script:<br><source>
+
<!--<ol><li value="3" style="margin-left:25px;">Issue the following commands (as a regular user) in order to setup, download and run the first unit feedback script:<br><source lang="bash">
 
mkdir -p ~/ops435/lab1/
 
mkdir -p ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd  #  <-- i.e. confirm that you are in the correct directory
 
pwd  #  <-- i.e. confirm that you are in the correct directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab0a
+
python3 ./CheckLab1.py -f -v lab0a
 
</source></li>
 
</source></li>
<li value="3" style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors in "lab1a.py".<br>When the check script tells you everything is "ok", you may proceed to the next step.<br><br></li><li style="margin-left:25px;">Make notes for all of your Investigation 1 (part1) observations in your lab log book, and proceed to part 2.</li></ol>
+
<li style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors from the check script.<br>When the check script tells you everything is "ok" for "lab0a", you may proceed to the next step.<br><br></li></ol>-->
  
 
=== PART 2 - Setting up Your Python Environment For Labs ===
 
=== PART 2 - Setting up Your Python Environment For Labs ===
  
In order to learn how to use python on your Linux machine, it is important to setup your Linux environment and learn how to interact with a Python shell.
+
In order to learn how to use python on your Linux machine, it is important to setup your Linux environment and learn how to interact with a Python shell. The following should be done on a terminal as the superuser (i.e. root).
  
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
  
:#The first step is to update your entire system. <source>
+
:#The first step is to update your entire system. <source lang="bash">
 
yum update
 
yum update
 
</source>
 
</source>
:#Install extra packages for enterprise linux<source>
+
:#Install extra packages for enterprise linux:<source lang="bash">
 
yum install epel-release  
 
yum install epel-release  
 
</source>
 
</source>
:#Next install applications we need, first Python version 3 and version 2:<source>
+
:#Next install applications that we required, first Python version 3 and version 2:<source lang="bash">
 
yum install python34 python34-devel # Install python3.4 and python3.4 development libraries
 
yum install python34 python34-devel # Install python3.4 and python3.4 development libraries
 
yum install python python2-devel # Install python2.7 and python2.7 development libraries
 
yum install python python2-devel # Install python2.7 and python2.7 development libraries
 
</source>
 
</source>
:#Next, you will install a couple of useful applications called '''tmux''' and '''screen'''. They are referred to as '''terminal multiplexers'''. If you plan to spend a lot of time in the terminal, this powerful tool will help you get it done. Lets install it and plan to use it later:<source>
+
:#We now need to create a link to python3.4:<source lang="bash">
 +
cd /bin
 +
ln -s python3.4 python3
 +
</source>
 +
:#Next, you will install a couple of useful applications called '''tmux''' and '''screen'''. They are referred to as '''terminal multiplexers'''. If you plan to spend a lot of time in the terminal, this powerful tool will help you get it done. Lets install it and plan to use it later:<source lang="bash">
 
yum install screen tmux && ln -s /usr/bin/true /etc/sysconfig/bash-prompt-screen
 
yum install screen tmux && ln -s /usr/bin/true /etc/sysconfig/bash-prompt-screen
 
</source>
 
</source>
:# You will now set your hostname to the Linux Distribution we are using:<source>
+
:# Set your hostname to the Linux Distribution we are using in case you did not set it correctly during the install process:<source lang="bash">
 
hostnamectl set-hostname centos7 # Set your hostname to distribution-name
 
hostnamectl set-hostname centos7 # Set your hostname to distribution-name
 
</source>
 
</source>
  
<blockquote style="margin-left:35px;">{{Admon/important|style="padding-left:25px"|Selecting a Text Editor|There are a wide range of text editors for the python language and just about any of them will do. As long as you get basic syntax highlighting and automatic indenting out of the application you are good to go. This section will go over a number of different text editors, showing off a few different text editors so students may find their favourite. There are no wrong answers here, give them all a try and use your favourite.<br><br>'''Vim'''<br>As a system administrator you have probably spent a ton of time inside vim. Well vim is just as powerful and useful when you get to programming, all the shortcuts and commands you've learned over the years will help you edit programs efficiently. On top of what you already know, it might be time to customize vim a little more for programming. Vim can actually be modified to become a full programming environment with all the features you you'd expect.<br><br>'''Atom'''<br>"A hackable text editor for the 21st Century". This text editor is a powerful tools that comes with everything your need right out of the box. Atom allows for deep customization from everything from complete functionality changes to just changing the theme. Definitely worth checking out, especially for python development.<br><br>'''Sublime'''<br>Insert discussion here}}</blockquote>
+
::You will be required to use a text editor in order to create and modify your Python scripts. There are many text editors that provide various features to become more comfortable and productive during your Python coding sessions.
 +
::Below is a listing of several common text editors and their features.
 +
<blockquote style="margin-left:35px;">{{Admon/tip|style="padding-left:25px"|Selecting an Appropriate Text Editor|
 +
'''Geany''' (recommended text editor for labs)<br>A simple graphical text editor for developers. It is available in the CentOS package repositories.<br>
 +
'''Vim'''<br>vim is a powerful text editor for system administration and programming tasks. All of the shortcuts and commands you've learned over the years will help you edit programs efficiently.<br>
 +
'''Sublime'''<br>Another powerful and popular text editor designed for programming. Is not free or open source.}}</blockquote>
  
<ol><li value=6" style="margin-left:25px;">Installing vim(Vi IMproved) will give us syntax highlighting and allow for advanced customization for terminal editing:<source>
+
<ol><li value=6" style="margin-left:25px;">'''Python pip''' is a package manager specifically for Python. While it is usually not recommended to install software outside of '''dnf''' or '''yum''', sometimes the only way to get a specific or latest version will be through pip:<source lang="bash">
yum install vim-common vim-enhanced # Install vim
 
</source></li>
 
<li style="margin-left:25px;"> Python pip is a package manager specifically for Python. While it is usually not recommended to install software outside of dnf or yum, sometimes the only way to get a specific or latest version will be through pip:<source>
 
 
yum install python-pip # Install python2.7 pip
 
yum install python-pip # Install python2.7 pip
 
yum install python34-pip # Install python3.4 pip
 
yum install python34-pip # Install python3.4 pip
 
</source></li>
 
</source></li>
<li style="margin-left:25px;">Issue the following command to install git:<source>
+
<li style="margin-left:25px;">Upgrade python34-pip with the following command:<source lang="bash">
 +
pip3.4 install --upgrade pip
 +
</source></li>
 +
<li style="margin-left:25px;">Issue the following command to install '''git''':<source lang="bash">
 
yum install git # Install git command line tool
 
yum install git # Install git command line tool
 
</source></li></ol>
 
</source></li></ol>
  
<blockquote style="margin-left:35px;">{{Admon/tip|What is a Git?|In the dictionary, "git" is defined as an unpleasant or contemptible person. In the IT industry on the other hand, '''Git''' refers to a version control system that allows you to track any changes made to files and programs. The benefit to using git is primarily found when it's used with multiple people, sharing and working on code together. While that is not how we will be using it in this course, you may find some benefits in using it for managing multiple versions of the same program or for backing up your code onto the internet. Check out bitbucket for a free private code repository.}}</blockquote>
+
<blockquote style="margin-left:35px;">{{Admon/tip|What is a Git?| '''Git''' refers to a '''version control system''' that allows you to track any changes made to files and programs. Our primary use for git in this course will be for backup onto to the internet. Check out '''bitbucket''' for a free private code repository.}}</blockquote>
  
<ol><li value="9" style="margin-left:25px;">IPython will be one of the tools we will use the most. Lets install it. You will learn more about it in the next section:<source>
+
<ol><li value="8" style="margin-left:25px;">IPython will be one of the tools we will use the most. Lets install it. You will learn more about it in the next section:<source lang="bash">
 
yum install python-ipython # Install ipython for python2.7
 
yum install python-ipython # Install ipython for python2.7
 
pip3.4 install ipython  # Install ipython for python3.4
 
pip3.4 install ipython  # Install ipython for python3.4
 
</source></li>
 
</source></li>
<li style="margin-left:25px;">Issue the following commands in your Ipython shell to check your work for this section:<source>
+
<li style="margin-left:25px;">Exit from the superuser shell to your regular user shell and issue the following commands to check your work for this section:<source lang="bash">
 +
mkdir -p ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
pwd #confirm that you are in the right directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab0b
+
python3 ./CheckLab1.py -f -v lab0a
 +
python3 ./CheckLab1.py -f -v lab0b
 
</source></li>
 
</source></li>
<li style="margin-left:25px;">Before moving on to the next step, make sure you identify and correct any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may proceed to the next step.
+
<li style="margin-left:25px;">Before moving on to the next step, make sure you identify and correct any and all errors in "lab0b" output. When the check script tells you everything is "ok", you may proceed to the next step.</li></ol>
 +
<br><br>
  
<pre>
+
= INVESTIGATION 2: USING THE "IPYTHON" CLI =
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
 
python ./CheckLab1.py -f -v lab0c
 
</pre>
 
</li>
 
<li style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may procede to the next step.<br><br></li>
 
<li style="margin-left:25px;">Make notes for all of your Investigation 1 (part1) observations in your lab log book, and proceed to investigation 2.</li></ol>
 
  
= INVESTIGATION 2: USING THE IPYTHON COMMAND LINE INTERFACE =
+
:'''IPython''' is an interactive environment that allows us to run python code line by line as we write it. This will also act like a bash shell prompt allowing users to enter a limited number of Bash shell commands. You will notice this by seeing an [IN] prompt where to enter commands and an [OUT] prompt that will display output from issued commands. We will start creating scripts out of the code within this '''IPython''' environment.
 +
<blockquote style="margin-left:35px;">{{Admon/important|style="padding-left:25px"|ipython and python|[https://plot.ly/python/ipython-vs-python/ What is the difference between '''python''' and '''ipython'''?] Please note that in later labs, you can use either '''python''' or '''ipythone''' as the interactive python shell.}}</blockquote>
  
:IPython is an interactive environment that allows us to run python code line by line as we write it. This will function almost exactly like a bash shell prompt, enter a command and recieve the output back. However the commands that we will be running are lines of python code. Using this method we will start creating scripts out of the code we build in the IPython environment.
 
  
 
=== PART 1 - Common Ipython Commands and Features ===
 
=== PART 1 - Common Ipython Commands and Features ===
Line 129: Line 138:
 
==== Using Magic Functions ====
 
==== Using Magic Functions ====
  
Lets start with trying to run some python code in a interactive shell. This is a advanced python shell, similar to the bash shell that you have been using throughout the linux courses.  
+
:Lets begin by running some python code in the ipython interactive shell. This is a advanced python shell, similar to the bash shell that you have been using throughout the Linux courses. Throughout these labs the term command can also refer to these "magical functions".
 
 
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
  
:#To get into the ipython shell type:<source>
+
:#Make sure you're using your regular user login and not using the root user for the following section.
 +
:#To access the '''ipython''' shell, issue the following command:<source>
 
ipython3
 
ipython3
</source>Now we are inside the IPython environment. We can run some basic bash commands in here, this is done through by using IPython magic functions. <br>
+
</source>Now we are now inside the IPython environment. We can run some basic bash commands within this shell by issuing IPython magic functions. <br>
 
:#Lets try a few commands out now:<source>
 
:#Lets try a few commands out now:<source>
%ls
+
ls
%pwd
+
pwd
%cd ~/
+
cd ~/
%ls
+
ls
</source>Now hold on. You are not using Python here. These are aliases, that IPython gives you access to. What you are actually using is bash, but not all bash commands are available in the IPython environment.<br><br>
+
</source>'''Remember:''' You are not using Python here, instead, these are aliases for Bash shell commands that IPython gives you access to. What you are actually using is bash, but not all bash commands are available in the IPython environment.<br><br>
 
:#Lets find out which ones are available, type the following command into the IPython shell:<source>
 
:#Lets find out which ones are available, type the following command into the IPython shell:<source>
%alias
+
alias
</source>We should now have a list of all the bash commands available in IPython. Shortly we will go over how to add new bash commands into this environment, but you must remember, these are only here to assist in your python scripting, we are not here to learn bash commands.<br><br>
+
</source>We should now have a list of all the bash commands available in IPython.
:#Next lets add a new bash command that seems to be missing from this list:<source>
 
%alias vim vim
 
</source>
 
:#The vim command will give us our much needed syntax highlighting, while we are editing scripts from within the IPython environment. These magic %alias functions do not save in between sessions, this creates a problem since you would have to create them every time you start IPython. This will create a error:<source>
 
exit
 
ipython3
 
%vim
 
</source> You should be seeing an error telling you invalid syntax. This is happening because we need to create a config file to make this alias persist in-between sessions.<br><br>
 
:#Exit your current IPython session:<source>
 
exit
 
</source>
 
:#Now, create a new file and add the following content to it:<source>
 
vim ~/.ipython/profile_default/startup/00-alias.ipy
 
</source>
 
:#Place our alias inside:<source>
 
%alias vim vim
 
</source>
 
:#Save and quit the file. Now lets return to our IPython shell and confirm that our alias is available right away:<source>
 
ipython3
 
%vim
 
</source><br>At this point vim should open successfully and you should now understand how to create new IPython aliases and store them persistently. Use these aliases to customize your environment with any bash commands you thing IPython is missing.<br><br>
 
:# Exit vim now and head back to the IPython shell. <br><br>
 
 
:#Lets setup a directory structures for completing and organizing labs. These should be the locations to store your lab scripts.<source>
 
:#Lets setup a directory structures for completing and organizing labs. These should be the locations to store your lab scripts.<source>
%mkdir ~/ops435
+
mkdir ~/ops435/lab2
%mkdir ~/ops435/lab1
+
mkdir ~/ops435/lab3
%mkdir ~/ops435/lab2
+
mkdir ~/ops435/lab4
%mkdir ~/ops435/lab3
+
mkdir ~/ops435/lab5
%mkdir ~/ops435/lab4
+
mkdir ~/ops435/lab6
%mkdir ~/ops435/lab5
+
mkdir ~/ops435/lab7
%mkdir ~/ops435/lab6
+
mkdir ~/ops435/lab8
%mkdir ~/ops435/lab7
 
%mkdir ~/ops435/lab8
 
 
</source>
 
</source>
:#If you are interested in finding more information about magic functions in IPython, try entering the IPython shell and typing the following:<source>
+
:#If you are interested in finding more information about other magic functions in IPython, then within the IPython shell, and enter the following (press the letter '''q''' to exit this function):<source>
%magic
+
magic
 
</source>
 
</source>
  
 +
:::This resource will appear OVERWHELMING (a huge amount of information)! As we move throughout this course, you will slowly use different magic functions from here, but we will never use all of them. They cover a huge range of different tasks, while we are writing code, allowing us to interactively inspect the Python we are writing and running. Lets move on for now.
  
:::This should show you a OVERWHELMING amount of information, as we move through the course we will slowly use different magic functions from here, but we will never use all of them. To be continued. Magic functions than just running bash commands. They cover a huge range of different tasks, while we are writing code, allowing us to interactively inspect the Python we are writing and running. Lets move on for now.
+
<ol><li value="6" style="margin-left:25px;">Issue the following command to exit your ipython session:<source>
 +
exit
 +
</source>
 +
</li>
 +
:In the future see if '''ctrl-d''' works instead of issuing the exit command to quit the ipython shell.
 +
</li>
  
 
+
<li style="margin-left:25px;">
<ol><li value="13" style="margin-left:25px;">Perform the following steps to evaluation this unit. Running this evaluation script will give you an error, read this error message to see if you can figure out why. This is happening because we are checking a lab script file that we HAVE NOT created yet, so these errors are ok for now. But run these check scripts regularly as you work through the labs, they may give you hints if you get stuck.  
+
Perform the following steps to evaluate this unit. Run these check scripts regularly as you work through the labs, they may give you hints if you get stuck.</li>
<pre>
+
:<source lang="bash">
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
pwd #confirm that you are in the right directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab1a
+
python3 ./CheckLab1.py -f -v lab0c
</pre>
+
</source>
</li>
+
</ol>
<li style="margin-left:25px;">Make notes for observations in your lab log book, and proceed to investigation 3.</li></ol>
+
<br><br>
 +
 
 +
= INVESTIGATION 3: WRITING PYTHON SCRIPTS =
  
 +
:In this investigation we will start writing our very first python scripts. These will be very basic and help us practice syntax and foundation skills, such as: outputting text to the screen, storing data inside objects, and using math operators.
  
= INVESTIGATION 3: WRITING A PYTHON SCRIPT =
+
<blockquote style="margin-left:35px;">{{Admon/important|style="padding-left:25px"|Object and Variable|The terms '''object''' and '''variable''' are used to refer to a data item in computer programming. The term '''variable''' are mostly used in 3rd generation programming/scripting languages (e.g. bash) while the term '''object''' is preferred in object oriented programming/scripting languages like Python. In the context of Python programming/scripting, When you see the term '''variable''' in the lab instructions, it can be replaced by the term '''object'''.}}</blockquote>
  
:During this investigation we will start writing our very first python scripts. These will be very basic and help us practice syntax and foundation skills, such as: outputting text to the screen, storing data inside variables, and using math operators.
 
  
 
=== PART 1 - Common Introductory Python Functions ===
 
=== PART 1 - Common Introductory Python Functions ===
  
====Printing Text====
+
====Creating the introductory "Hello World" Script====
  
Lets start IPython interpreter and start writing some python code.
+
You will learn to create a simple python script in this section. This python script will just print the text "hello world". The "hello world" an old traditional first program students usually are taught to create, which is based on the first programming example from the first C programming text co-written by Dennis Ritchie, the creator of the C programming language and Brian Kernighan. You will learn how to run the python script in the python3 shell as well as learn how to run the python script from the bash shell.
  
 +
:'''Perform the following steps:'''
  
'''Perform the following steps:'''
 
  
:#Issue the following commands:<source>
+
:#Create a new python file in your ~/ops435/lab1 directory. Call it lab1a.py. The first Python code we will write is going to call the print function. A function is code that has been defined in another location. Functions can take arguments, use these arguments in some way, and then usually return a result. The first function we will use is the "print()" functions, it's sole purpose is to output information to the screen.<br><br>
ipython3
+
:#Add the following line into your source code file:<source>
%cd ~/ops435/lab1
 
%pwd
 
%ls
 
</source>Our first python code we will write is the print function. A function is code that has been defined in another location. Functions can take arguments, use these arguments in some way, and then usually return a result. The first function we will use is the "print()" functions, it's sole purpose is to output information to the screen.<br><br>
 
:#At the prompt, issue the following python function:<source>
 
 
print()
 
print()
</source>You will notice that nothing happened when we ran this "print()" function. This is because we didn't pass any arguments to it, lets try again.<br><br>
+
</source>And run it from the command-line: <source>python3 ./lab1a.py</source>You will notice that nothing is printed even though we called the "print()" function. This is because we didn't pass any arguments to it, lets try again.<br><br>
:# Issue the following function:<br><source>
+
:# Modify your call to print() to inlcude an argument ('hello world'):<br><source>
 
print('hello world')
 
print('hello world')
</source>This time we should now see that the python function "print()" has outputted to the screen the words 'hello world'. In python a word or a bunch of characters like 'hello world' is called a 'string'. So what we did above is, passed a '''string''' as a '''argument''' to the print '''function'''. These words are important for understanding and talking about different aspects of code.
+
</source>This time we should now see that the python function "print()" has outputted to the screen the words 'hello world'. In python a word or a bunch of characters like 'hello world' is called a 'string'. In the above example, a '''string''' was passed as a '''argument''' to the print '''function'''. These words are important for understanding and talking about different aspects of code.<br><br>
 
+
:# Note that there are similarities between the Python print() function and the Bash echo command, but Python is more picky than bash (which is a good thing). Try to run print without the brackets or without the quotes to see what happens.
====Creating the introductory "Hello World" Script====
+
<blockquote style="margin-left:35px;">{{Admon/tip|Reading errors|One of the things that makes a good programmer is debugging skills. The first and most important debugging technique is reading and understanding error messages. Try to understand what the errors are saying even if you think you already know what the problem is and already have some idea about how to fix it.}}</blockquote>
 
+
<ol><li value="5" style="margin-left:25px;">Write the following code into our python file. Note the she-bang line at the top of the file to run this script in the python3 environment. You will need to add this she-bang line for all python scripts you create for this course.<source lang="python">
Next, we will make our first script with the above function. Open a new text file called "lab1a.py".
 
 
 
'''Perform the following steps:'''
 
 
 
:# Edit the following file:<source>
 
%vim ~/ops435/lab1/lab1a.py
 
</source>  
 
:#Write the following code into our python file. <source>
 
 
#!/usr/bin/env python3
 
#!/usr/bin/env python3
  
Line 246: Line 226:
 
print('Hello world')
 
print('Hello world')
 
</source>
 
</source>
:#Save the file and quit vim. We will now go over the process of manually running this python script. Both in the Bash shell and in the IPython shell.
+
<li style="margin-left:25px;">Another way of running a pythion program is executing it directly, e.g.: <source>./test.py</source>Note that the file will need execute permissions even though you ran it just fine earlier. Why is that?
:#Now lets try running the script directly from the IPython shell by issuing the follwoing commands:<source>
+
<li style="margin-left:25px;">Download the check script and check your work. Enter the following commands from the bash shell.<source lang="bash">
ipython3
+
cd ~/ops435/lab1/
%run ~/ops435/lab1/lab1a.py
+
pwd #confirm that you are in the right directory
</source><br><br>Your python script should have run, if you have any errors you should check that you typed the script in exactly. Be careful of extra spaces, symbols, letters, or lowercase/uppercase differences.<br><br>
+
ls lab1a.py #confirm that you have the lab1a.py script in your directory
:#Exit out of IPython.  
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
:#Now, from the Bash shell we will give it the correct linux permissions and run it. This is just showing the multiple ways you can use this python script. You are not required to have IPython running on a system, however hopefully we can use IPython's powerful features to our advantage.
+
python3 ./CheckLab1.py -f -v lab1a
:# Issue the following command to exit your ipython session:<source>
 
exit
 
 
</source>
 
</source>
:# Run your python script by issuing the following commands:<source>
+
<li style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may proceed to the next step.
chmod 755 ~/ops435/lab1/lab1a.py
+
</ol>
python3 ~/ops435/lab1/lab1a.py
+
 
</source>
+
=== PART 2 - Working with Python Objects ===
:#Download the check script and check your work. Enter the following commands from the bash shell.<source>
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
ls lab1a.py #confirm that you have the lab1a.py script in your directory
 
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
 
python ./CheckLab1.py -f -v lab1a
 
</source>
 
:#Before moving on to the next step make sure you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may proceed to the next step.
 
:#Make notes for observations in your lab log book, and proceed to part 2.
 
  
=== PART 2 - Working with Variables ===
+
:In Python, an object is used to store data for use later in the program. This data can be a string, integer, decimal number, characters, etc. We will only be covering '''string''' and '''integer''' variables in this lab. You will learn and use other python object types in future labs.
  
A variable is used to store data for use later in the program. This data can be a string, integer, decimal, etc.
+
==== String Objects ====
  
==== String Variables ====
+
:String objects contain text to be used in your program. Examples of strings could be user-names, full-names, item descriptions, etc. We will now demonstrate to assign a string to an object and how to display contents stored in a string object.
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
  
:#First, let's make a new variable containing a value by issuing the following command:<source>
+
:#Create a python script (called lab1b.py) and first - start with a few simple things to try:
name = 'Thomas'
+
:#Let's make a new object containing a value:<source lang="python">
 +
name = 'Thomas'
 
</source>
 
</source>
:#Iss the following command to inspect the value of the variable"<source>
+
:#Print the value to the screen:<source lang="python">
name
+
print(name)
 
</source>
 
</source>
:#Print the value to the screen:<source>
+
:#Think about why this does something different:<source lang="python">
print(name)
+
print('name')
 
</source>
 
</source>
:#Now lets try something new, we are going to print out the string and concatenate/combine it with another string. The plus sign can be used to join 2 strings together. However, make sure that your variable is always outside the quotes, or it will not resolve to a value.<source>
+
:#Now lets try something new, we are going to print out the string and concatenate/combine it with another string. The plus sign can be used to join 2 strings together. However, make sure that your object is always outside the quotes, or it will not resolve to a value.<source lang="python">
 
print('I have a friend named ' + name)
 
print('I have a friend named ' + name)
 
</source>
 
</source>
:#To gain practice, create a python script (called lab1b.py) with the following content and details:
+
:#To gain practice, complete your python script with the following content and details:
::::* The script should have a Shebang line
+
::::* The script should have a '''Shebang line''' like you did for your lab1a.py python script
::::* The script should use a single variable called "name"
+
::::* The script should use a single object called "name"
::::* The value of the "name" variable should be "Isaac"
+
::::* The value of the "name" object should be "Isaac"
 
::::* The script, when executed, should print out "How old are you Isaac?"
 
::::* The script, when executed, should print out "How old are you Isaac?"
 
::::*Sample run: <source>
 
::::*Sample run: <source>
%cd ~/ops435/lab1/
+
cd ~/ops435/lab1/
%run ./lab1b.py
+
./lab1b.py
How old are you Isaac?
+
How old are you Isaac?
 
</source>Try the checking script as you are working through a script to sometimes get hints.<br><br>
 
</source>Try the checking script as you are working through a script to sometimes get hints.<br><br>
<ol><li value="6" style="margin-left:25px;">Download and run the checking script. Enter the following commands from the bash shell:<source>
+
<ol><li value="7" style="margin-left:25px;">Download and run the checking script. Enter the following commands from the '''bash shell''':<source lang="bash">
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
pwd #confirm that you are in the right directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab1b
+
python3 ./CheckLab1.py -f -v lab1b
 
</source></li>
 
</source></li>
<li style="margin-left:25px;"> Before proceeding, make certain that you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may procede to the next step.</li></ol>
+
<li style="margin-left:25px;"> Before proceeding, make certain that you identify any and all errors in "lab1b.py". When the check script tells you everything is "ok", you may proceed to the next step.</li></ol>
  
==== Integer Variables====
+
==== Integer Objects====
  
Lets enter into IPython to test out variables.
+
:In Python, integer objects are used to store an integer numbers that can be used for mathematical operations (discussed in the next section). Integers do NOT contain decimals, and they can be signed (+ or -) or unsigned. Here we will store integers in a object, perform math operations, and display the results.
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
  
:#Enter the following command to access the python prompt:<source>
+
:#Create a python script (called lab1c.py) and first - start with a few simple things to try:  
ipython3
+
:#Lets create some new objects to play with.<source lang="python">
</source>
 
:#Lets create some new variables to play with.<source>
 
 
num1 = 5
 
num1 = 5
 
num2 = 10
 
num2 = 10
</source><br>In IPython we can inspect these variables by just typing the name of the variable. But in a python script this will not provide any output. This feature is useful however for debugging.<br><br>
 
:#Issue the following commands:<source>
 
num1
 
num2
 
 
</source>
 
</source>
:#Now we will make a new variable and try some math:<source>
+
:#You can print the values in those integer objects:<source lang="python">
 +
print(num1)
 +
print(num2)
 +
</source>
 +
:#Now we will make a new integer object and try some math:<source lang="python">
 
sum = num1 + num2
 
sum = num1 + num2
</source><br>This will add the values contained in the variables together, providing a sum. However you will note that there is no output. First lets inspect the new value.<br><br>
+
</source>This will add the values contained in the integer objects together, providing a sum. However you will note that there is no output. Let's inspect the new value:<source lang="python">
:#Enter the following command:<source>
 
sum
 
</source><br>Does this value look right? If we wanted to print this out to the screen we could use the following python code.<br><br>
 
:#Enter the following function:<source>
 
 
print(sum)
 
print(sum)
</source>
+
</source>Does this value look right? Are you sure?<br>
:#Now lets try printing this sum out with a string:<source>
+
:#Now lets try printing this sum out with a string:<source lang="python">
 
print('The sum is: ' + sum)
 
print('The sum is: ' + sum)
</source><br>What happened? Did you receive an error? This will may have been the first time you've seen this error, but it won't be the last. What we tried to do is combine a string with a number, and this won't work.<br><br>In order to use display this number as a string we will use the "str()" function on it. The "str()" function will return a string of your number and provide it as a argument to "print()". This function will not change the value of your variable, your variable is still a interger.<br><br>
+
</source>What happened? Did you receive an error? This will may have been the first time you've seen this error, but it won't be the last. What we tried to do is combine a string with a number, and this won't work.<br><br>In order to use display this number as a string we will use the "str()" function on it. The "str()" function will return a string of your number and provide it as a argument to "print()". This function will not change the value of your object, your object is still an interger object.<br><br>
:# Issue the following:<source>
+
:# Issue the following:<source lang="python">
 
print('The sum is: ' + str(sum))
 
print('The sum is: ' + str(sum))
</source><br>What did you notice this time?<br>
+
</source>What did you notice this time?<br />
:#To gain practice, create a python script (called lab1c.py) with the following content and details:
+
:#To gain practice, complete your python script with the following features:
 
:::* The script should have a Shebang line.
 
:::* The script should have a Shebang line.
:::* The script should have a variable called '''name'''
+
:::* The script should have an object called '''name'''
:::* The script should have a variable called '''age'''
+
:::* The script should have an object called '''age'''
:::* The value of the '''name''' variable should be '''Isaac'''
+
:::* The value of the '''name''' object should be '''Isaac'''
:::* The variable '''age''' should contain a integer
+
:::* The object '''age''' should contain a integer
:::* The value of the '''age''' variable should be '''72'''
+
:::* The value of the '''age''' object should be '''72'''
 
:::* The script, when executed, should print out "Isaac is 72 years old!"
 
:::* The script, when executed, should print out "Isaac is 72 years old!"
 
:::Example run: <source>
 
:::Example run: <source>
%cd ~/ops435/lab1/
+
cd ~/ops435/lab1/
%run ./lab1c.py
+
./lab1c.py
 
Isaac is 72 years old!
 
Isaac is 72 years old!
 
</source><br>Try the check script as you are working through a script to sometimes get hints.<br>
 
</source><br>Try the check script as you are working through a script to sometimes get hints.<br>
<ol><li value=10" style="margin-left:25px;">Download and run the checking script. Enter the following commands from the bash shell:<source>
+
<ol><li value=10" style="margin-left:25px;">Download and run the checking script. Enter the following commands from the bash shell:<source lang="bash">
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
pwd #confirm that you are in the right directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab1c
+
python3 ./CheckLab1.py -f -v lab1c
 
</source></li>
 
</source></li>
<li  style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may procede to the next step.</li>
+
<li  style="margin-left:25px;">Before moving on to the next step make sure you identify any and all errors in "lab1c.py". When the check script tells you everything is "ok", you may proceed to the next step.</li>
<li  style="margin-left:25px;">Make notes for observations in your lab log book, and proceed to part 3.</li></ol>
+
</ol>
  
 
=== PART 5 - MATH OPERATORS ===
 
=== PART 5 - MATH OPERATORS ===
  
Python has a number of math operators you can use in your programs.
+
:In the previous section, you performed a couple of simple mathematical operations. In this section, you will learn some additional mathematical operations.  
  
'''Perform the following steps:'''
+
:'''Perform the following steps:'''
:# Issue the following commands to see how they operate in the ipython shell:<source>
+
 
10 + 5    # addition
+
:# Try some of the following to see what happens in Python:<source lang="python">
10 - 5    # subtraction
+
print(10 + 5)   # addition
10 * 5    # multiplication
+
print(10 - 5)   # subtraction
10 / 5    # division
+
print(10 * 5)   # multiplication
10 ** 5  # exponents
+
print(10 / 5)   # division
 +
print(10 ** 5)   # exponents
 
</source>NOTE: You must be careful when combining more complex math operators together. Python uses '''PEMDAS''' ('''P'''arentheses, '''E'''xponents, '''M'''ultiplication and '''D'''ivision, '''A'''ddition and '''S'''ubtraction) to resolve math.<br><br>
 
</source>NOTE: You must be careful when combining more complex math operators together. Python uses '''PEMDAS''' ('''P'''arentheses, '''E'''xponents, '''M'''ultiplication and '''D'''ivision, '''A'''ddition and '''S'''ubtraction) to resolve math.<br><br>
:# Go over the below examples and see if you understand each situation:<source>
+
:# Go over the below examples and see if you understand each situation:<source lang="python">
10 + 5 * 2 # multiplication happens before addition
+
print(10 + 5 * 2) # multiplication happens before addition
(10 + 5) * 2 # parentheses happen before multiplication
+
print((10 + 5) * 2) # parentheses happen before multiplication
10 + 5 * 2 - 10 ** 2 # first exponents, then multiplication, then addition and subtraction from left-to-right
+
print(10 + 5 * 2 - 10 ** 2) # first exponents, then multiplication, then addition and subtraction from left-to-right
15 / 3 * 4 # division and multiplication happen from left-to-right
+
print(15 / 3 * 4) # division and multiplication happen from left-to-right
100 / ((5 + 5) * 2) # the inner most parentheses are first performing addition, then parentheses again with multiplication, finally the division  
+
print(100 / ((5 + 5) * 2)) # the inner most parentheses are first performing addition, then parentheses again with multiplication, finally the division  
 
</source>
 
</source>
:#To gain practice, create a python script (called lab1d.py) with the following content and details:
+
:#To gain practice, complete your script with the following content and details:
 
::* The script should have a Shebang line.
 
::* The script should have a Shebang line.
::* The variable '''x''' should contain a integer with the value '''10'''
+
::* The object '''x''' should contain a integer with the value '''10'''
::* The variable '''y''' should contain a integer with the value '''2'''
+
::* The object '''y''' should contain a integer with the value '''2'''
::* The variable '''z''' should contain a integer with the value '''5'''
+
::* The object '''z''' should contain a integer with the value '''5'''
::* The script, when executed, should print out "10 + 2 * 5 = 20"
+
::* The script, when executed, should print out "10 + 2 * 5 = 20" (the printout should change if the values in the objects change)
 
:::Example run: <source>
 
:::Example run: <source>
%cd ~/ops435/lab1/
+
cd ~/ops435/lab1/
%run ./lab1d.py
+
./lab1d.py
 
10 + 2 * 5 = 20
 
10 + 2 * 5 = 20
 
</source>Try the checking script as you are working through a script to sometimes get hints.<br><br>
 
</source>Try the checking script as you are working through a script to sometimes get hints.<br><br>
<ol><li style="margin-left:25px;" value="4">Download and run the checking script. Enter the following commands from the bash shell:<source>
+
<ol><li style="margin-left:25px;" value="4">Download and run the checking script. Enter the following commands from the bash shell:<source lang="bash">
 
cd ~/ops435/lab1/
 
cd ~/ops435/lab1/
 
pwd #confirm that you are in the right directory
 
pwd #confirm that you are in the right directory
ls CheckLab1.py || wget matrix.senecacollege.ca/~acoatley-willis/CheckLab1.py
+
ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
python ./CheckLab1.py -f -v lab1d
+
python3 ./CheckLab1.py -f -v lab1d
</source>Before moving on to the next step make sure you identify any and all errors in "lab1a.py".<br><br></li>
+
</source>Before moving on to the next step make sure you identify any and all errors in "lab1d.py".<br><br></li>
<li style="margin-left:25px;">When the check script tells you everything is "ok", you may procede to the next step.<br><br></li>
+
<li style="margin-left:25px;">When the check script tells you everything is "ok", you may proceed to the next step.<br><br></li>
<li  style="margin-left:25px;">Make notes for observations in your lab log book, and proceed to Lab 1 Instructor Sign-off.</li>
 
 
</ol>
 
</ol>
 
+
<br><br>
  
 
= LAB 1 SIGN-OFF (SHOW INSTRUCTOR) =
 
= LAB 1 SIGN-OFF (SHOW INSTRUCTOR) =
Line 409: Line 373:
 
:'''Have Ready to Show Your Instructor:'''
 
:'''Have Ready to Show Your Instructor:'''
  
::<span style="color:green;font-size:1.5em;">&#x2713;</span>x
+
::<span style="color:green;font-size:1.5em;">&#x2713;</span> Output of: <code>./CheckLab1.py -f -v</code>
::<span style="color:green;font-size:1.5em;">&#x2713;</span> x
+
::<span style="color:green;font-size:1.5em;">&#x2713;</span> Output of: <code>cat lab1a.py lab1b.py lab1c.py lab1d.py</code>
::<span style="color:green;font-size:1.5em;">&#x2713;</span> Lab1 logbook notes completed
+
 
 +
:'''Be able to answer any questions about the lab to show that you understood it!'''
 +
<br>
 +
:'''For sections A & B:'''
 +
 
 +
::<span style=color:green;font-size:1.5em;">&#x2713;</span> Submit your output and Python scrips via Blackboard instead.
 +
 
 +
= LAB REVIEW =
 +
 
 +
:# Write the command to change the hostname of your Linux machine to '''centos7'''.
 +
:# What is the purpose of '''git'''? How will git be used in our OPS435 course?
 +
:# Write the command to create an '''alias''' for the Linux command vim which will be called vi in your ipython3 session.
 +
:# Write the absolute pathname for the ipython3 alias configuration file.
 +
:# Write Python code that when run, will perform the following tasks:<ol type="a"><li>Contain a she-bang line</li><li>Display a greetings message to the user</li><li>display an empty line ('''hint:''' use the special character '''\n''' to print the a new-line character)</li><li>Display text, '''"Your current directory is:"''' (You are NOT required to display quotation marks)</li><li>Display the current working directory pathname (using an appropriate command)</li><li>Display another empty line</li></ol>
 +
:# How do you execute a Python script when you are within the <u>ipython3</u> shell?
 +
:# How do you execute a Python script when you are in the <u>Bash</u> Shell (i.e. NOT within the Ipython3 shell)?
 +
:# Write the pipeline command to check if the CheckLab1.py checking script exists, and download it from the location:<br>https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
 +
 
 +
[[Category:OPS435-Python]]

Latest revision as of 09:25, 21 January 2020

** DO NOT USE - TO BE UPDATED FOR CENTOS 8.0 **

LAB OBJECTIVES

In this lab, you will install a current distribution of Linux in a Virtual Machine on your external SSD. You will do all of your future work within this VM (including quizzes!). You will then setup your Python scripting environment on your host machine, including the setup the of python libraries and also the setup of a user-friendly interactive Python environment called ipython. You will also install additional framework tools (such as git, vim, and tmux) to be used in later labs.
After selecting an appropriate text editor to use, then you will start to create Python scripts to learn basic operations such as: printing text, using objects, and performing math operations.



INVESTIGATION 1: INSTALLING LINUX VM

PART 1 - Installing Your Linux Distribution

Centos 7 - release 1810 will be used for this course. The purpose for this is to allow you to use a consistent and stable RedHat based OS, and to lower the amount of new linux distros that you need to learn.
Most of you will likely use the school's Windows machines with the Vmware hypervisor. It is also possible to use your own computer, but check with your professor before you do that.
Centos 7 comes with python 2.7, for this course we will be primarily using Python3. However, not practicing python 2.7 would be a mistake, since so many programs and operating systems still depend on Python2. It is recommended that students note general improvements/differences in Python2 and Python3.


Centos 7 VM Details / Minimum Requirements:
  • Name: centos7
  • Boot media / Installation: CentOS7 Full Install DVD
  • Disk space: 50GB
  • CPUs: 4 (Number of processors: 1, Number of cores per processor: 4)
  • Internal Memory: 8GB
  • Environment: GNOME Desktop


Perform the following steps:
  1. Regardless of the Linux distribution that is used for this course, these lab will be using and referring to the current version of CentOS 7 (Graphical Desktop) for our main Linux machine. When creating your VM, refer to the Details / Minimum Requirements section above for assistance.
  2. Install CentOS 7 VM selecting the default partitions. When you have finished the installation of CentOS 7, you may proceed to the next step.
Important.png
Unit Feedback Scripts
Each Part (within an 'Investigation) is referred to as a Unit. Each Unit will require that the student download and run a Unit Feedback Script, which provides the OPS435 student "real-time feedback" of their completed work.
This feedback is not considered to be perfect or fool-proof; however, it may provide feedback (hints) in case a student gets stuck or experiences an error when performing administration tasks or when creating their Python scripts. These unit feedback scripts can also be used to confirm that the student's Python script is on the right track, and provide a consistent record of their Python scripting progress throughout their labs.


PART 2 - Setting up Your Python Environment For Labs

In order to learn how to use python on your Linux machine, it is important to setup your Linux environment and learn how to interact with a Python shell. The following should be done on a terminal as the superuser (i.e. root).


Perform the following steps:
  1. The first step is to update your entire system.
    yum update
  2. Install extra packages for enterprise linux:
    yum install epel-release
  3. Next install applications that we required, first Python version 3 and version 2:
    yum install python34 python34-devel # Install python3.4 and python3.4 development libraries
    yum install python python2-devel # Install python2.7 and python2.7 development libraries
  4. We now need to create a link to python3.4:
    cd /bin
    ln -s python3.4 python3
  5. Next, you will install a couple of useful applications called tmux and screen. They are referred to as terminal multiplexers. If you plan to spend a lot of time in the terminal, this powerful tool will help you get it done. Lets install it and plan to use it later:
    yum install screen tmux && ln -s /usr/bin/true /etc/sysconfig/bash-prompt-screen
  6. Set your hostname to the Linux Distribution we are using in case you did not set it correctly during the install process:
    hostnamectl set-hostname centos7 # Set your hostname to distribution-name
You will be required to use a text editor in order to create and modify your Python scripts. There are many text editors that provide various features to become more comfortable and productive during your Python coding sessions.
Below is a listing of several common text editors and their features.
Idea.png
Selecting an Appropriate Text Editor

Geany (recommended text editor for labs)
A simple graphical text editor for developers. It is available in the CentOS package repositories.
Vim
vim is a powerful text editor for system administration and programming tasks. All of the shortcuts and commands you've learned over the years will help you edit programs efficiently.

Sublime
Another powerful and popular text editor designed for programming. Is not free or open source.
  1. Python pip is a package manager specifically for Python. While it is usually not recommended to install software outside of dnf or yum, sometimes the only way to get a specific or latest version will be through pip:
    yum install python-pip # Install python2.7 pip
    yum install python34-pip # Install python3.4 pip
  2. Upgrade python34-pip with the following command:
    pip3.4 install --upgrade pip
  3. Issue the following command to install git:
    yum install git # Install git command line tool
Idea.png
What is a Git?
Git refers to a version control system that allows you to track any changes made to files and programs. Our primary use for git in this course will be for backup onto to the internet. Check out bitbucket for a free private code repository.
  1. IPython will be one of the tools we will use the most. Lets install it. You will learn more about it in the next section:
    yum install python-ipython # Install ipython for python2.7
    pip3.4 install ipython  # Install ipython for python3.4
  2. Exit from the superuser shell to your regular user shell and issue the following commands to check your work for this section:
    mkdir -p ~/ops435/lab1/
    cd ~/ops435/lab1/
    pwd #confirm that you are in the right directory
    ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
    python3 ./CheckLab1.py -f -v lab0a
    python3 ./CheckLab1.py -f -v lab0b
  3. Before moving on to the next step, make sure you identify and correct any and all errors in "lab0b" output. When the check script tells you everything is "ok", you may proceed to the next step.



INVESTIGATION 2: USING THE "IPYTHON" CLI

IPython is an interactive environment that allows us to run python code line by line as we write it. This will also act like a bash shell prompt allowing users to enter a limited number of Bash shell commands. You will notice this by seeing an [IN] prompt where to enter commands and an [OUT] prompt that will display output from issued commands. We will start creating scripts out of the code within this IPython environment.
Important.png
ipython and python
What is the difference between python and ipython? Please note that in later labs, you can use either python or ipythone as the interactive python shell.


PART 1 - Common Ipython Commands and Features

Using Magic Functions

Lets begin by running some python code in the ipython interactive shell. This is a advanced python shell, similar to the bash shell that you have been using throughout the Linux courses. Throughout these labs the term command can also refer to these "magical functions".
Perform the following steps:
  1. Make sure you're using your regular user login and not using the root user for the following section.
  2. To access the ipython shell, issue the following command:
    ipython3
    Now we are now inside the IPython environment. We can run some basic bash commands within this shell by issuing IPython magic functions.
  3. Lets try a few commands out now:
     ls
     pwd
     cd ~/
     ls
    Remember: You are not using Python here, instead, these are aliases for Bash shell commands that IPython gives you access to. What you are actually using is bash, but not all bash commands are available in the IPython environment.

  4. Lets find out which ones are available, type the following command into the IPython shell:
     alias
    We should now have a list of all the bash commands available in IPython.
  5. Lets setup a directory structures for completing and organizing labs. These should be the locations to store your lab scripts.
     mkdir ~/ops435/lab2
     mkdir ~/ops435/lab3
     mkdir ~/ops435/lab4
     mkdir ~/ops435/lab5
     mkdir ~/ops435/lab6
     mkdir ~/ops435/lab7
     mkdir ~/ops435/lab8
  6. If you are interested in finding more information about other magic functions in IPython, then within the IPython shell, and enter the following (press the letter q to exit this function):
     magic
This resource will appear OVERWHELMING (a huge amount of information)! As we move throughout this course, you will slowly use different magic functions from here, but we will never use all of them. They cover a huge range of different tasks, while we are writing code, allowing us to interactively inspect the Python we are writing and running. Lets move on for now.
  1. Issue the following command to exit your ipython session:
     exit
  2. In the future see if ctrl-d works instead of issuing the exit command to quit the ipython shell.
  3. Perform the following steps to evaluate this unit. Run these check scripts regularly as you work through the labs, they may give you hints if you get stuck.
  4. cd ~/ops435/lab1/
    pwd #confirm that you are in the right directory
    ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
    python3 ./CheckLab1.py -f -v lab0c



INVESTIGATION 3: WRITING PYTHON SCRIPTS

In this investigation we will start writing our very first python scripts. These will be very basic and help us practice syntax and foundation skills, such as: outputting text to the screen, storing data inside objects, and using math operators.
Important.png
Object and Variable
The terms object and variable are used to refer to a data item in computer programming. The term variable are mostly used in 3rd generation programming/scripting languages (e.g. bash) while the term object is preferred in object oriented programming/scripting languages like Python. In the context of Python programming/scripting, When you see the term variable in the lab instructions, it can be replaced by the term object.


PART 1 - Common Introductory Python Functions

Creating the introductory "Hello World" Script

You will learn to create a simple python script in this section. This python script will just print the text "hello world". The "hello world" an old traditional first program students usually are taught to create, which is based on the first programming example from the first C programming text co-written by Dennis Ritchie, the creator of the C programming language and Brian Kernighan. You will learn how to run the python script in the python3 shell as well as learn how to run the python script from the bash shell.

Perform the following steps:


  1. Create a new python file in your ~/ops435/lab1 directory. Call it lab1a.py. The first Python code we will write is going to call the print function. A function is code that has been defined in another location. Functions can take arguments, use these arguments in some way, and then usually return a result. The first function we will use is the "print()" functions, it's sole purpose is to output information to the screen.

  2. Add the following line into your source code file:
    print()
    And run it from the command-line:
    python3 ./lab1a.py
    You will notice that nothing is printed even though we called the "print()" function. This is because we didn't pass any arguments to it, lets try again.

  3. Modify your call to print() to inlcude an argument ('hello world'):
    print('hello world')
    This time we should now see that the python function "print()" has outputted to the screen the words 'hello world'. In python a word or a bunch of characters like 'hello world' is called a 'string'. In the above example, a string was passed as a argument to the print function. These words are important for understanding and talking about different aspects of code.

  4. Note that there are similarities between the Python print() function and the Bash echo command, but Python is more picky than bash (which is a good thing). Try to run print without the brackets or without the quotes to see what happens.
Idea.png
Reading errors
One of the things that makes a good programmer is debugging skills. The first and most important debugging technique is reading and understanding error messages. Try to understand what the errors are saying even if you think you already know what the problem is and already have some idea about how to fix it.
  1. Write the following code into our python file. Note the she-bang line at the top of the file to run this script in the python3 environment. You will need to add this she-bang line for all python scripts you create for this course.
    #!/usr/bin/env python3
    
    # Any line that starts with a "#" is also known as a comment,
    # these lines are ignored by the python interpreter even if
    # they contain code. The very first line is called a Shebang line, 
    # it is used to tell the system which interpreter to 
    # use(python2, python3, bash, etc). 
    
    # Description: This program will output "hello world" to the screen
    
    print('Hello world')
  2. Another way of running a pythion program is executing it directly, e.g.:
    ./test.py
    Note that the file will need execute permissions even though you ran it just fine earlier. Why is that?
  3. Download the check script and check your work. Enter the following commands from the bash shell.
     cd ~/ops435/lab1/
     pwd #confirm that you are in the right directory
     ls lab1a.py #confirm that you have the lab1a.py script in your directory
     ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
     python3 ./CheckLab1.py -f -v lab1a
  4. Before moving on to the next step make sure you identify any and all errors in "lab1a.py". When the check script tells you everything is "ok", you may proceed to the next step.

PART 2 - Working with Python Objects

In Python, an object is used to store data for use later in the program. This data can be a string, integer, decimal number, characters, etc. We will only be covering string and integer variables in this lab. You will learn and use other python object types in future labs.

String Objects

String objects contain text to be used in your program. Examples of strings could be user-names, full-names, item descriptions, etc. We will now demonstrate to assign a string to an object and how to display contents stored in a string object.
Perform the following steps:
  1. Create a python script (called lab1b.py) and first - start with a few simple things to try:
  2. Let's make a new object containing a value:
    name =  'Thomas'
  3. Print the value to the screen:
    print(name)
  4. Think about why this does something different:
    print('name')
  5. Now lets try something new, we are going to print out the string and concatenate/combine it with another string. The plus sign can be used to join 2 strings together. However, make sure that your object is always outside the quotes, or it will not resolve to a value.
    print('I have a friend named ' + name)
  6. To gain practice, complete your python script with the following content and details:
  • The script should have a Shebang line like you did for your lab1a.py python script
  • The script should use a single object called "name"
  • The value of the "name" object should be "Isaac"
  • The script, when executed, should print out "How old are you Isaac?"
  • Sample run:
     cd ~/ops435/lab1/
     ./lab1b.py
     How old are you Isaac?
    Try the checking script as you are working through a script to sometimes get hints.

  1. Download and run the checking script. Enter the following commands from the bash shell:
    cd ~/ops435/lab1/
    pwd #confirm that you are in the right directory
    ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
    python3 ./CheckLab1.py -f -v lab1b
  2. Before proceeding, make certain that you identify any and all errors in "lab1b.py". When the check script tells you everything is "ok", you may proceed to the next step.

Integer Objects

In Python, integer objects are used to store an integer numbers that can be used for mathematical operations (discussed in the next section). Integers do NOT contain decimals, and they can be signed (+ or -) or unsigned. Here we will store integers in a object, perform math operations, and display the results.
Perform the following steps:
  1. Create a python script (called lab1c.py) and first - start with a few simple things to try:
  2. Lets create some new objects to play with.
    num1 = 5
    num2 = 10
  3. You can print the values in those integer objects:
    print(num1)
    print(num2)
  4. Now we will make a new integer object and try some math:
    sum = num1 + num2
    This will add the values contained in the integer objects together, providing a sum. However you will note that there is no output. Let's inspect the new value:
    print(sum)
    Does this value look right? Are you sure?
  5. Now lets try printing this sum out with a string:
    print('The sum is: ' + sum)
    What happened? Did you receive an error? This will may have been the first time you've seen this error, but it won't be the last. What we tried to do is combine a string with a number, and this won't work.

    In order to use display this number as a string we will use the "str()" function on it. The "str()" function will return a string of your number and provide it as a argument to "print()". This function will not change the value of your object, your object is still an interger object.

  6. Issue the following:
    print('The sum is: ' + str(sum))
    What did you notice this time?
  7. To gain practice, complete your python script with the following features:
  • The script should have a Shebang line.
  • The script should have an object called name
  • The script should have an object called age
  • The value of the name object should be Isaac
  • The object age should contain a integer
  • The value of the age object should be 72
  • The script, when executed, should print out "Isaac is 72 years old!"
Example run:
cd ~/ops435/lab1/
./lab1c.py
Isaac is 72 years old!

Try the check script as you are working through a script to sometimes get hints.
  1. Download and run the checking script. Enter the following commands from the bash shell:
    cd ~/ops435/lab1/
    pwd #confirm that you are in the right directory
    ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
    python3 ./CheckLab1.py -f -v lab1c
  2. Before moving on to the next step make sure you identify any and all errors in "lab1c.py". When the check script tells you everything is "ok", you may proceed to the next step.

PART 5 - MATH OPERATORS

In the previous section, you performed a couple of simple mathematical operations. In this section, you will learn some additional mathematical operations.
Perform the following steps:
  1. Try some of the following to see what happens in Python:
    print(10 + 5)    # addition
    print(10 - 5)    # subtraction
    print(10 * 5)    # multiplication
    print(10 / 5)    # division
    print(10 ** 5)   # exponents
    NOTE: You must be careful when combining more complex math operators together. Python uses PEMDAS (Parentheses, Exponents, Multiplication and Division, Addition and Subtraction) to resolve math.

  2. Go over the below examples and see if you understand each situation:
    print(10 + 5 * 2)		# multiplication happens before addition
    print((10 + 5) * 2) 		# parentheses happen before multiplication
    print(10 + 5 * 2 - 10 ** 2)	# first exponents, then multiplication, then addition and subtraction from left-to-right
    print(15 / 3 * 4)		# division and multiplication happen from left-to-right
    print(100 / ((5 + 5) * 2))	# the inner most parentheses are first performing addition, then parentheses again with multiplication, finally the division
  3. To gain practice, complete your script with the following content and details:
  • The script should have a Shebang line.
  • The object x should contain a integer with the value 10
  • The object y should contain a integer with the value 2
  • The object z should contain a integer with the value 5
  • The script, when executed, should print out "10 + 2 * 5 = 20" (the printout should change if the values in the objects change)
Example run:
cd ~/ops435/lab1/
./lab1d.py
10 + 2 * 5 = 20
Try the checking script as you are working through a script to sometimes get hints.

  1. Download and run the checking script. Enter the following commands from the bash shell:
    cd ~/ops435/lab1/
    pwd #confirm that you are in the right directory
    ls CheckLab1.py || wget https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py
    python3 ./CheckLab1.py -f -v lab1d
    Before moving on to the next step make sure you identify any and all errors in "lab1d.py".

  2. When the check script tells you everything is "ok", you may proceed to the next step.



LAB 1 SIGN-OFF (SHOW INSTRUCTOR)

Students should be prepared with all required commands (system information) displayed in a terminal (or multiple terminals) prior to calling the instructor for signoff.


Have Ready to Show Your Instructor:
Output of: ./CheckLab1.py -f -v
Output of: cat lab1a.py lab1b.py lab1c.py lab1d.py
Be able to answer any questions about the lab to show that you understood it!


For sections A & B:
Submit your output and Python scrips via Blackboard instead.

LAB REVIEW

  1. Write the command to change the hostname of your Linux machine to centos7.
  2. What is the purpose of git? How will git be used in our OPS435 course?
  3. Write the command to create an alias for the Linux command vim which will be called vi in your ipython3 session.
  4. Write the absolute pathname for the ipython3 alias configuration file.
  5. Write Python code that when run, will perform the following tasks:
    1. Contain a she-bang line
    2. Display a greetings message to the user
    3. display an empty line (hint: use the special character \n to print the a new-line character)
    4. Display text, "Your current directory is:" (You are NOT required to display quotation marks)
    5. Display the current working directory pathname (using an appropriate command)
    6. Display another empty line
  6. How do you execute a Python script when you are within the ipython3 shell?
  7. How do you execute a Python script when you are in the Bash Shell (i.e. NOT within the Ipython3 shell)?
  8. Write the pipeline command to check if the CheckLab1.py checking script exists, and download it from the location:
    https://raw.githubusercontent.com/Seneca-CDOT/ops435/master/LabCheckScripts/CheckLab1.py